博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[置顶] SPL讲解(6)--Condition篇
阅读量:4983 次
发布时间:2019-06-12

本文共 3030 字,大约阅读时间需要 10 分钟。

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语句进行查询的。

转载于:https://www.cnblogs.com/james1207/p/3328909.html

你可能感兴趣的文章
poj 1564
查看>>
asp.net 自己收集的面试题
查看>>
JAVA编程思想的理解
查看>>
base64 json
查看>>
对Axure软件的使用介绍
查看>>
守护态运行
查看>>
Java虚拟机JVM学习04 类的初始化
查看>>
GJM : 各大开发游戏引擎
查看>>
read view初探
查看>>
59%亚洲制造企业暂未引入人工智能, 但这场求变风险值得一试
查看>>
c#二维码资料
查看>>
多列索引
查看>>
产品多属性搜索实现
查看>>
前端学习-01 input属性type
查看>>
关于 lambda expression 返回值的类型转换
查看>>
phpStorm 快捷键收集以及配色方案
查看>>
c++的set_unexpected不起作用
查看>>
让 Homebrew 走代理更新 + brew 管理 node 版本
查看>>
ORACLE用SYS登录报ORA-28009:connection as SYS should be as SYSDBA OR SYSOPER解决方法
查看>>
ora-12514 tns listener does not currently know of service requested in connect descriptor
查看>>