Mybatis的or逻辑

Mybatis代码生成器生成的Example中的 Criteria可以用来组装sql语句。其中or逻辑的组装有点不好理解。

Criteria
Criteria包含一个Cretiron的集合,每一个Criteria对象内包含的Cretiron之间是由AND连接的,是逻辑与的关系。

oredCriteria
Example内有一个成员叫oredCriteria,是Criteria的集合,就想其名字所预示的一样,这个集合中的Criteria是由OR连接的,是逻辑或关系。oredCriteria就是ORed Criteria。

使用or逻辑的两个例子:
1.
TestTableExample example = new TestTableExample();
  example.or()
    .andField1EqualTo(5)
    .andField2IsNull();
  example.or()
    .andField3NotEqualTo(9)
    .andField4IsNotNull();
  List<Integer> field5Values = new ArrayList<Integer>();
  field5Values.add(8);
  field5Values.add(11);
  field5Values.add(14);
  field5Values.add(22);
  example.or()
    .andField5In(field5Values);
  example.or()
    .andField6Between(3, 7);

or()方法会产生一个新的Criteria对象,添加到oredCriteria中,并返回这个Criteria对象,从而可以链式表达,为其添加Criterion。产生的动态SQL是这样的:
where (field1 = 5 and field2 is null)
     or (field3 <> 9 and field4 is not null)
     or (field5 in (8, 11, 14, 22))
     or (field6 between 3 and 7)

===
2.
ViewPsmsgconsultExample example=new ViewPsmsgconsultExample(); 
ViewPsmsgconsultExample.Criteria criteria=example.createCriteria(); 
criteria.andToidEqualTo(mctid); 
criteria.andStatusEqualTo("0"); 
         
ViewPsmsgconsultExample.Criteria criteria2=example.createCriteria(); 
criteria2.andToidEqualTo(mctid); 
criteria2.andLaststatusEqualTo("0"); 
example.or(criteria2); 
psmsgconsultDao.countByExample(example); 

select count(*) from VIEW_PSMSGCONSULT WHERE ( TOID = ? and STATUS = ? ) or( TOID = ? and LASTSTATUS = ? )

这两种方式得到的结果一样的,写法上有些不同。要运行时查看生成的详细sql语句,使用下面log4j的配置


log4j.rootLogger=debug,...

...

###显示SQL语句部分
log4j.logger.com.ibatis=DEBUG
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG

log4j.logger.java.sql.PreparedStatement=DEBUG

 

http://ljhzzyx.blog.163.com/blog/static/38380312201412043525595/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值