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开发 ...
随机推荐
- js制作圆角按钮(兼容谷歌,ie7,ie8)
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- Shape 与 InlineShape 的区别
Shape 对象代表文档中的图形对象,InlineShape 代表文档中的嵌入式图形对象.所谓嵌入式图形对象,是指将图像作为文字处理,在排版上以文字的方式进行排版. Shape 与 InlineSha ...
- eclipse 修改设置Ctrl+Shift+F长度
在window的Preferences中的Java->Code Style->Formatter 到了这一步就是找到Ctrl+Shift+F的格式化模板了,这里不能直接修改.因为是ecli ...
- SQL Server 地理数据库中的系统表
转自:http://resources.arcgis.com/zh-cn/help/main/10.1/index.html#/na/002q00000080000000/ 地理数据库的系统表可以强制 ...
- 《转》如何让你的网页加载时间降低到 1s 内
当初分析了定宽高值和定宽高比这两种常见的图片延迟加载场景,也介绍了他们的应对方案,还做了一点技术选型的工作. 经过一段时间的项目实践,在先前方案的基础上又做了很多深入的优化工作.最终将好奇心日报的网页 ...
- ReaderWriterLock类(转)
ReaderWriterLock类 通常来讲,一个类型的实例对于并行的读操作是线程安全的,但是并行地更新操作则不是(并 行地读和更新也不是). 这对于资源也是一样的,比如一个文件.当保护类型的实例安全 ...
- Oracle.ManagedDataAccessDTC.dll 使用
ODP.NET, Managed Driver Setup This section explains the setup and configuration steps required for u ...
- 调试 Azure 云服务项目的方法
调试 Azure 云服务项目 在菜单栏中选择“调试”>“启动调试”(键盘操作:F5). 重要提示 如果未将 Azure 云服务项目设置为启动项目,当你单击按钮以触发断点时,将出现以下错误:“外部 ...
- HOG特征
HOG(Histogram of gradient)统计图像局部区域的梯度方向信息来作为该局部图像区域的表征.HOG特征具有以下几个特点: (1)不具有旋转不变性(较大的方向变化),实际应用中不变性是 ...
- Introduction to SignalR -摘自网络
What is SignalR? ASP.NET SignalR is a library for ASP.NET developers that simplifies the process of ...