听棠.NET

用积极乐观的心态,面对压力
posts - 307, comments - 10812, trackbacks - 112, articles - 5
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

SmartPersistenceLayer 2.0(6) ---Condition篇

Posted on 2004-11-15 15:35 听棠.NET 阅读(...) 评论(...) 编辑 收藏
 

SmartPersistenceLayer 2.0 Condition

原理

       强大的Condition功能是SPL的一个特性,可以使用Condition完成绝大部分的条件定义,使用也是最广泛的,RetrieveCriteria,UpdateCriteria,DeleteCriteria,Query,只要用到查询条件的地方,都会使用此Condition类.

       Condition的实例化方式:

RetrieveCriteria rc=new RetrieveCriteria(typeof(StudentEntity));

Condition c=rc.GetNewCondition();

UpdateCriteria uc=new UpdateCriteria (typeof(StudentEntity));

Condition c=uc.GetNewCondition();

DeleteCriteria dc=new DeleteCriteria (typeof(StudentEntity));

Condition c=dc.GetNewCondition();

Query q=new Query(typeof(StudentEntity));

Condition c=q. GetQueryCondition();

 

Condition内部是and关系,Condition之间,是以”Or”的方式组合的

如:

RetrieveCriteria rc=new RetrieveCriteria(typeof(StudentEntity));

Condition c=rc.GetNewCondition();

c.AddEqualTo(StudentEntity.Name,”tintown”);

c.AddNotEqualTo(StudentEntity.Sex,’’);

Condition c2=rc.GetNewCondition();

c2.AddEqualTo(StudentEntity.Id,”1”);

这样会产生”(Name=’tintown’ and Sex<>’’) or Id=1”这样的结果.

 

常用条件

下面以RetrieveCriteria rc=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=c. GetNewOrGroup();  //实例一个OrGroup 原来写错了:OrGroup og=rc. GetNewOrGroup();
og.AddEqualTo(…);                           //条件C

og.AddEqualTo(…);                           //条件 D

CD形成一个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语句进行查询的。

 

 听棠

200411

MSNtintown_liu@hotmail.com