lsjORM ----让开发变得更加快捷(二)
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 ----让开发变得更加快捷(二)的更多相关文章
- Android开发艺术探索笔记——View(二)
Android开发艺术探索笔记--View(二) View的事件分发机制 学习资料: 1.Understanding Android Input Touch Events System Framewo ...
- SNF开发平台WinForm之十二-发送手机短信功能调用-金笛-SNF快速开发平台3.3-Spring.Net.Framework
1.调用前组装参数 2.调用发送信息服务脚本 .调用前组装参数: BaseSendTaskEntity entity = new BaseSendTaskEntity(); entity.Mess ...
- spring 第一篇(1-1):让java开发变得更简单(下)
切面(aspects)应用 DI能够让你的软件组件间保持松耦合,而面向切面编程(AOP)能够让你捕获到在整个应用中可重用的组件功能.在软件系统中,AOP通常被定义为提升关注点分离的一个技术.系统由很多 ...
- spring 第一篇(1-1):让java开发变得更简单(下)转
spring 第一篇(1-1):让java开发变得更简单(下) 这个波主虽然只发了几篇,但是写的很好 上面一篇文章写的很好,其中提及到了Spring的jdbcTemplate,templet方式我之前 ...
- Scrum&Kanban在移动开发团队的实践 (二)
Scrum&Kanban在移动开发团队的实践系列: Scrum&Kanban在移动开发团队的实践 (一) Scrum&Kanban在移动开发团队的实践 (二) 在第一篇分享文章 ...
- 基于.net开发chrome核心浏览器【二】
原文:基于.net开发chrome核心浏览器[二] 一: 上一篇的链接: 基于.net开发chrome核心浏览器[一] 二: 相关资源介绍: chrome Frame: 让IE有一颗chrome的心, ...
- PHP微信支付开发之扫描支付(模式二)后如何回调
其实在写这篇文章的时候感觉自己已经落伍了,不过笔者在百度上搜索"微信支付开发之扫描支付(模式二)后如何回调"寻找答案时,发现依旧有很多朋友没有解决这个问题,所以就把自己的解决思路分 ...
- Java开发微信公众号(二)---开启开发者模式,接入微信公众平台开发
接入微信公众平台开发,开发者需要按照如下步骤完成: 1.填写服务器配置 2.验证服务器地址的有效性 3.依据接口文档实现业务逻辑 资料准备: 1.一个可以访问的外网,即80的访问端口,因为微信公众号接 ...
- 转载:百为STM32开发板教程之十二——NAND FLASH
http://bbs.21ic.com/icview-586200-1-1.html 百为STM32开发板教程之十二——NAND FLASH 参考资料:百为stm32开发板光盘V3\百为stm32开发 ...
随机推荐
- VS2010中的调试技巧
作者: scottgu 这是我的博客中关于VS 2010和.NET 4发布系列的第二十六篇文章. 今天的博文将介绍Visual Studio中的一些实用调试技巧.这是受我朋友Scott Cate (他 ...
- 转载-smarty教程(基本语法)
转自:http://hi.baidu.com/qxxgvpdtzhbckpr/item/681049160d7be60db98a1aec 1.smarty的配置 首先,使用smarty第一件 ...
- selenium2.0 处理各种窗口问题解决方法
selenium2.0处理muti-Windows . Frames .Popup Dialogs selenium2.0处理多窗口,弹窗等,只需要调用WebDriver 嵌套类:TargetLoca ...
- 【wuzhicms】apache 设置禁止访问某些文件或目录
[apache配置禁止访问] 1. 禁止访问某些文件/目录 增加Files选项来控制,比如要不允许访问 .inc 扩展名的文件,保护php类库: <Files ~ "\.inc$&qu ...
- Python安装、配置
1.Python简介:Python在Linux.windows.Mac os等操作系统下都有相应的版本,不管在什么操作系统下,它都能够正常工作.除非使用平台相关功能,或特定平台的程序库,否则可以跨平台 ...
- JQ限制输入字数,并提示剩余字数
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- IOS GCD 使用(三)单例模式
一 Dispatch_once函数简介 使用dispatch_once提价的代码块,即便你提交多次,只能执行一次. void dispatch_once(dispatch_once_ ...
- ubuntu14.04中安装QuartusII9.1步骤
家里的计算机安装了WIN10,出于够用且安装文件小,想安装QuartusII9.1,按M$风格,驱动绝对是安不上的.正好是双系统ubuntu14.04 64位.安装过程不太顺利,记录下来,当作已经不灵 ...
- Windows下Apache+Tomcat+jsp+php的服务器整合配置经验总结
对于Apache+Tomcat+jsp+php的整合,针对不同的Tomcat和apache的版本,稍微有些区别. 一.所需软件 (1)JDK: jdk-7u15-windows-x64.exejdk的 ...
- codeforces 132C Logo Turtle--- dp dfs
题目在这里:点击打开链接 题意: F表示前进一步,T表示变成反方向 给一串FT字符,和一个n,表示可以改变多少次,求可以走到的离原点最远的距离 改变就是F变成T.T变成F 关键: dfs(int d, ...