lsjORM结构

跟传统三层没有多大区别,这里添加DTO(参数列表)跟PetaPoce(数据库操作),普通的三层我们都喜欢用DBHelper或者SqlHelper来封装sql的辅助方法,PetaPoce更加强大,网上已经有不少资料了,很容易就能学会它

lsjORM参数列表类(Dtb_Base)

sql语句很重要的一部分就是where后面的条件,这里的参数列表主要是为了补充sql语句的where部分,而且只用写一次,在所有的地方都可以直接调用,打个比方,我需要查询age > 16 and sex = 1

的所有学生,这个sql就用到两个参数,比如我要删除age > 16 and sex = 1的所有学生,又需要重复的写where,这是一件麻烦的事,我们可以通过dto很好的解决它.

DTO的主要作用就是用来给Sql语句追加where后面的参数,常用于表里某个字段 > n, <n, =n, like n, in n

你可以很方便的定义它,就跟定义model里面的属性一样,并且写上注释,让调用它的人能直接明白意思

-----------------------------------------------------------------定义DTO--------------------------------------------------------

  public partial class Dtb_Users : Dtb_Base
{
/// <summary>
/// 根据组别查询
/// </summary>
public int? Group_id { get; set; } /// <summary>
/// 根据mobile查询
/// </summary>
public string Mobile { get; set; } private List<string> _inNickName = new List<string>(); /// <summary>
/// 查找集合里匹配的所有数据
/// </summary>
public List<string> InNickName
{
get { return _inNickName; }
set { _inNickName = value; }
}
}

这里我在Dtb_User类里定义了3个参数,分部是Group_id,Mobile,InNickName ,我可以根据这三个参数任意的组合查询条件,比如查询用户表里某个集合用户里面属于某个组的所有用户....你可以根据需求随意的定义它们.

-----------------------------------------------------------------实现DTO--------------------------------------------------------

                     /// <summary>
/// 重写参数列表
/// </summary>
/// <param name="dto"></param>
/// <returns></returns>
public override Sql GetWhere(Dtb_Base dto)
{
Dtb_Users dto_users = dto as Dtb_Users;
var sql = new CZDBUtility.PetaPoco.Sql();
if (dto.id.HasValue)
{
sql.Where("id=@0", dto.id);
}
if (!string.IsNullOrEmpty(dto_users.Mobile))
{
sql.Where("mobile=@0", dto_users.Mobile);
}
if (dto_users.Group_id.HasValue)
{
sql.Where("Group_id=@0", dto_users.Group_id);
}
if (dto_users.InNickName.Count > )
{
sql.Where("Nick_name in(@0)", dto_users.InNickName);
}
return sql;
}

当定义了参数列表后,必须要在对应的B层去实现它,否则无效,可以看到这是一个简单的拼接where条件的方法.

PS:DTO一个参数列表,用来传递参数的载体

-----------------------------------------------------------------实现增删改查操作--------------------------------------------------------

  public ActionResult Index()
{
//Common.CreateFile cf = new Common.CreateFile();
//cf.CreateEntityAll(); B_Users b_user = new B_Users();
//============添加一个用户===========================
M_Users m_user = new M_Users();
m_user.User_name = "";
m_user.Mobile = "";
m_user.Nick_name = "aabb";
m_user.Password = "";
var res = b_user.Add(m_user); //返回添加成功后的id //============查询单个用户===========================
m_user = b_user.GetModel(res); //根据id查询单个用户
Dtb_Users dto = new Dtb_Users();
dto.Mobile = "";
m_user = b_user.GetModel(dto); //根据dto查询单个用户,如果出现多条数据,则返回第一条 //============查询多个用户===========================
List<M_Users> list_user = b_user.GetList(dto); //查询用户集合,不分页
dto.page.Page_Size = ; //每页条数
dto.page.Current_Page = ;//页码
dto.page.Order_field = "id desc";//排序方式
dto.page.CentSize = ; //中间码,给分页控件调用,如果中间页数超过这个数,则用...代替
list_user = b_user.GetList(dto); //查询用户集合,分页,排序
//dto.page.Object_Count 当查询结束后,dto会自动获取总条数
//dto.page.Page_Num 当查询结束后,dto会自动获取总页数 //============修改用户信息===========================
m_user.Mobile = "";
bool bl = b_user.Edit(m_user); //============删除用户===========================
bl = b_user.Del(res); //根据id删除用户 ViewData.Add("list_user", list_user);
return View();
}

非常简单就可以完成这些基本操作,下一章讲解怎么联合查询,实现事务.

QQ群:567951547

lsjORM ----让开发变得更加快捷(二)的更多相关文章

  1. Android开发艺术探索笔记——View(二)

    Android开发艺术探索笔记--View(二) View的事件分发机制 学习资料: 1.Understanding Android Input Touch Events System Framewo ...

  2. SNF开发平台WinForm之十二-发送手机短信功能调用-金笛-SNF快速开发平台3.3-Spring.Net.Framework

    1.调用前组装参数 2.调用发送信息服务脚本   .调用前组装参数: BaseSendTaskEntity entity = new BaseSendTaskEntity(); entity.Mess ...

  3. spring 第一篇(1-1):让java开发变得更简单(下)

    切面(aspects)应用 DI能够让你的软件组件间保持松耦合,而面向切面编程(AOP)能够让你捕获到在整个应用中可重用的组件功能.在软件系统中,AOP通常被定义为提升关注点分离的一个技术.系统由很多 ...

  4. spring 第一篇(1-1):让java开发变得更简单(下)转

    spring 第一篇(1-1):让java开发变得更简单(下) 这个波主虽然只发了几篇,但是写的很好 上面一篇文章写的很好,其中提及到了Spring的jdbcTemplate,templet方式我之前 ...

  5. Scrum&Kanban在移动开发团队的实践 (二)

    Scrum&Kanban在移动开发团队的实践系列: Scrum&Kanban在移动开发团队的实践 (一) Scrum&Kanban在移动开发团队的实践 (二) 在第一篇分享文章 ...

  6. 基于.net开发chrome核心浏览器【二】

    原文:基于.net开发chrome核心浏览器[二] 一: 上一篇的链接: 基于.net开发chrome核心浏览器[一] 二: 相关资源介绍: chrome Frame: 让IE有一颗chrome的心, ...

  7. PHP微信支付开发之扫描支付(模式二)后如何回调

    其实在写这篇文章的时候感觉自己已经落伍了,不过笔者在百度上搜索"微信支付开发之扫描支付(模式二)后如何回调"寻找答案时,发现依旧有很多朋友没有解决这个问题,所以就把自己的解决思路分 ...

  8. Java开发微信公众号(二)---开启开发者模式,接入微信公众平台开发

    接入微信公众平台开发,开发者需要按照如下步骤完成: 1.填写服务器配置 2.验证服务器地址的有效性 3.依据接口文档实现业务逻辑 资料准备: 1.一个可以访问的外网,即80的访问端口,因为微信公众号接 ...

  9. 转载:百为STM32开发板教程之十二——NAND FLASH

    http://bbs.21ic.com/icview-586200-1-1.html 百为STM32开发板教程之十二——NAND FLASH 参考资料:百为stm32开发板光盘V3\百为stm32开发 ...

随机推荐

  1. 【HtmlParser】HtmlParser使用

    转载 http://www.cnblogs.com/549294286/archive/2012/09/04/2670601.html HTMLParser的核心模块是org.htmlparser.P ...

  2. HTMLParser 使用详解

    htmlparser是一个纯的java写的html解析的库,它不依赖于其它的java库文件,主要用于改造或   提取html.它能超高速解析html,而且不会出错.现在htmlparser最新版本为2 ...

  3. windows查看服务端口

    开始--运行--cmd 进入命令提示符 输入netstat -ano 即可看到所有连接的PID 之后在任务管理器中找到这个PID所对应的程序如果任务管理器中没有PID这一项,可以在任务管理器中选&qu ...

  4. c# 中Intern的作用

    1. 函数如下 public static string Intern(string str) { if(str == null) { throw new ArgumentNullException( ...

  5. 关于 Unity 中 ModelImporter.optimizeGameObjects

         ModelImporter.optimizeGameObjects 能够优化骨骼动画,将无用的骨骼合并,效率测试官方给出的数据差距比较大( Unity CJ 干货分享:全新的Unity移动游 ...

  6. shell常识总结

    #!/bin/bash cmd="ls -lt | grep ^d | awk 'NR==1 {print $9}'" $cmd 这是一个获取文件夹名字的脚本,但是却提示: ls: ...

  7. centos "cannot open display"的问题

    实用技巧:在Linux下设置xhost方法步骤 第一步:用root登陆linux,启动vnc服务: 第二步:根据vnc起来的端口,设置export DISPLAY=localhost:1(1表示vnc ...

  8. POJ-3678 Katu Puzzle 2sat

    题目链接:http://poj.org/problem?id=3678 分别对and,or,xor推出相对应的逻辑关系: 逻辑关系 1 0  A and B     A'->A,B'->B ...

  9. CMDB, 配置管理数据库, ITIL - ManageEngine ServiceDesk Plus

    Download Bitnami Review Board Stack click here CMDB, 配置管理数据库, ITIL - ManageEngine ServiceDesk Plus

  10. fzu2109--Mountain Number(数位dp)

     Problem Description One integer number x is called "Mountain Number" if: (1) x>0 and x ...