[置顶] SPL讲解(6)--Condition篇
SmartPersistenceLayer 2.0 之 Condition篇
原理
强大的Condition功能是SPL的一个特性,可以使用Condition完成绝大部分的条件定义,使用也是最广泛的,如RetrieveCriteria,UpdateCriteria,DeleteCriteria,Query等,只要用到查询条件的地方,都会使用此Condition类.
Condition的实例化方式:
RetrieveCriteriarc=new RetrieveCriteria(typeof(StudentEntity));
Conditionc=rc.GetNewCondition();
或
UpdateCriteria uc=newUpdateCriteria (typeof(StudentEntity));
Conditionc=uc.GetNewCondition();
或
DeleteCriteria dc=newDeleteCriteria (typeof(StudentEntity));
Conditionc=dc.GetNewCondition();
或
Query q=newQuery(typeof(StudentEntity));
Condition c=q.GetQueryCondition();
Condition内部是and关系,Condition之间,是以”Or”的方式组合的
如:
RetrieveCriteriarc=new RetrieveCriteria(typeof(StudentEntity));
Conditionc=rc.GetNewCondition();
c.AddEqualTo(StudentEntity.Name,”tintown”);
c.AddNotEqualTo(StudentEntity.Sex,’男’);
Conditionc2=rc.GetNewCondition();
c2.AddEqualTo(StudentEntity.Id,”1”);
这样会产生”(Name=’tintown’ andSex<>’男’) or Id=1”这样的结果.
常用条件
下面以RetrieveCriteriarc=new RetrieveCriteria(typeof(StudentEntity));
Condition c=rc.GetNewCondition();
AddEqualTo (=)
相等比较:会生成类似”where name=’tintown’”的语句, 例如:
c.AddEqualTo(“Name”,”tintown”);
AddGreaterThan(>)
大于比较:会生成类似” where price > 1000”的语句
c.AddGreaterThan(“Price”,1000);
AddGreaterThanOrEqualTo(>=)
大于等于比较: 会生成类似” where price >= 1000”的语句
c.AddGrearterThanOrEqualTo(“Price”,1000);
AddNotEqualTo(<>)
不等于比较: 会生成类似” where name<>’tintown’”的语句
c.AddNotEqualTo(“Name”,”tintown”);
AddLessThan(<)
小于比较: 会生成类似” where price < 1000”的语句
c.AddLessThan(“Price”,1000);
AddLessThanOrEqualTo(<=)
小于等于比较: 会生成类似” where price <= 1000”的语句
c.AddLessThanOrEqualTo(“Price”,1000);
AddMatch(like ‘%A%’)
匹配比较: 会生成类似” where name like ‘%刘%’”的语句
c.AddMatch(“Name”,”刘”);
AddMatchPrefix(like ‘A%’)
前匹配比较: 会生成类似” where name like ‘刘%”的语句
c.AddMatchPrefix(“Name”,”刘”);
AddIn(in (A))
IN比较: 会生成类似” where name in (‘K’,’ I’)”的语句
string[] where=new string[]{“K”,”I”}
c.AddIn(“Name”,where);
OrGroup条件类[2.0新增功能]
在常规中,我们注意到,很难实现A and B and ( C or D)这样的效果,所以在这里添加了OrGroup类。
OrGroup是指Or的组,在OrGroup内,关系都是Or,所以可以通过以下代码要实现:
RetrieveCriteria rc=new RetrieveCriteria(typeof(StudentEntity));
Condition c=rc.GetNewCondition();
c.AddEqualTo(….) //条件A
c.AddEqualTo(….) //条件B
OrGroup og=rc. GetNewOrGroup(); //实例一个OrGroup
og.AddEqualTo(…); //条件C
og.AddEqualTo(…); //条件 D
C和D形成一个Or组,这样就实现了A and B and ( C or D)
通过以上方式可以实现更强的条件定义
字段与字段比较[2.0新增功能]
为了字段与字段的比较,为此扩展了查询条件,
字段间相等AddEqualToField
c.AddEqualToField(“field1”,field2);
这会生成类似”where field1=field2”
字段间大于AddGreaterThanField
c. AddGreaterThanField (“field1”,field2);
这会生成类似”where field1>field2”
字段间大于等于AddGreaterThanOrEqualToField
c. AddGreaterThanOrEqualToField (“field1”,field2);
这会生成类似”where field1>=field2”
字段间不等于AddNotEqualToField
c. AddNotEqualToField (“field1”,field2);
这会生成类似”where field1<>field2”
字段间小于AddLessThanField
c. AddLessThanField (“field1”,field2);
这会生成类似”where field1<field2”
字段间小于等于AddLessThanOrEqualToField
c. AddLessThanOrEqualToField (“field1”,field2);
这会生成类似”where field1<=field2”
总结
SPL虽然提供了很强的条件定义功能,如果遇到特别复杂的条件,还是需要自己手写SQL语句进行查询的。
[置顶] SPL讲解(6)--Condition篇的更多相关文章
- [置顶] SPL讲解(4)--Criteria操作篇
概念 以前一篇文章中,描述了实体Entity的操作,很明显,仅仅实体的操作是远远不够的.如:我们经常会根据查询条件从数据库中获取记录集并绑定到DataGrid上,会根据条件进行批量的Update和De ...
- [置顶] SPL讲解(7)--Query高级篇
SmartPersistenceLayer 2.0 之Query高级查询篇 总述 在看了前面的功能后,大家都会考虑到多表之间的查询怎么办.在这里,我想先讲一下查询在应用系统中的复杂性/重要性/可行性. ...
- [知了堂学习笔记]_css3特效第二篇--行走的线条&&置顶导航栏
一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...
- css3特效第二篇--行走的线条&&置顶导航栏
一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...
- 让WPF的Popup不总置顶的解决方案
使用WPF的Popup的时候会发现有一个问题,它总是会置顶,只要Popup的StayOpen不设置为False,它就一直呆在最顶端,挡住其他的窗口. 解决方案是继承Popup重新定义控件PopupEx ...
- [置顶] 创建GitHub技术博客全攻略
[置顶] 创建GitHub技术博客全攻略 分类: GitHub2014-07-12 13:10 19710人阅读 评论(21) 收藏 举报 githubio技术博客网站生成 说明: 首先,你需要注册一 ...
- About me & 一些置顶的博文
About me 一只历史上最弱的 \(\text{hnoier}\) ... 身在 \(\text{hn}\) 弱校,除了在四大名校夹缝中生存,还要受到同校 \(\text{Julao}\) 的鄙视 ...
- Ionic-wechat项目边开发边学(四):可伸缩输入框,下拉刷新, 置顶删除
摘要 上一篇文章主要介绍了ion-list的使用, ion-popup的使用, 通过sass自定义样式, localStorage的使用, 自定义指令和服务. 这篇文章实现的功能有消息的置顶与删除, ...
- thinkphp内置标签简单讲解
thinkphp内置标签简单讲解 1.volist循环 name 需要遍历的数据 id 类似于foreach中 value offset 截取数据起始位置 length 截取数据的个数 mod 奇偶数 ...
随机推荐
- ArcGIS API for Silverlight开发入门
你用上3G手机了吗?你可能会说,我就是喜欢用nokia1100,ABCDEFG跟我 都没关系.但你不能否认3G是一种趋势,最终我们每个人都会被包裹在3G网络中.1100也不是一成不变,没准哪天为了打击 ...
- vijos1777 引水入城
描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使居民们都尽可能 ...
- Factorials 阶乘
Description N的阶乘写作N!表示小于等于N的所有正整数的乘积.阶乘会很快的变大,如13!就必须用32位整数类型来存储,70!即使用浮点数也存不下了.你的任务是找到阶乘最后面的非零位.举个例 ...
- Smallest Rectangle Enclosing Black Pixels 解答
Question An image is represented by a binary matrix with 0 as a white pixel and 1 as a black pixel. ...
- 【HDU 4738 Caocao's Bridges】BCC 找桥
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4738 题意:给定一个n个节点m条边的无向图(可能不连通.有重边),每条边有一个权值.判断其连通性,若双 ...
- Linux系统启动流程及grub重建(1)
日志系统 Linux系统启动流程 PC: OS(Linux) POST-->BIOS(Boot Sequence)-->MBR(bootloader,446)-->Kernel--& ...
- jquery ajax 局部table 刷新技术
点击查询:
- python学习之路-4 内置函数和装饰器
本篇涉及内容 内置函数 装饰器 内置函数 callable() 判断对象是否可以被调用,返回一个布尔值 1 2 3 4 5 6 7 8 9 10 11 num = 10 print(callabl ...
- 浅谈jquery关于select框的取值和赋值
浅谈jquery关于select框的取值和赋值 jQuery("#select_id").change(function(){}); // 1.为Select添加事件,当选择其 ...
- 导致flash屏幕重绘的几种方式及避免重绘的方法
导致屏幕重绘的几种原因: 1.最常见的是情况就是舞台上的可视组件在形状.位置.状态(alpha, scale…)发生改变的时候会触发Flash Player 的重绘. 2.当一个DisplayObje ...