Mybatis的or逻辑
来源:互联网 发布:android网络响应速度 编辑:程序博客网 时间:2024/05/29 11:41
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/
0 0
- Mybatis的or逻辑
- mybatis OR语句的写法
- mybatis 中 or 的使用
- 简单的 数据库 and or 逻辑
- python的and 和or逻辑
- mybatis处理and、or关系的方法
- mybatis 写in or 子句的语法
- mybatis createcriteria和or的区别
- mybatis处理and、or关系的方法
- mybatis处理and、or关系的方法
- mybatis处理and、or关系的方法
- 关于Hibernate QBC语句逻辑或(or)的查询方法
- MyBatis的criteria的or(或查询)语法
- Hibernate or Mybatis
- mybatis or 操作
- Mybatis 查询 or 语句
- 【JAVA-Mybatis】MyBatis 常用逻辑符号转换
- Mybatis 逻辑与物理分页
- xdebug安装
- 几招解决google无法打开的问题
- 加法运算(java)
- UVA - 11542 Square (异或方程组)
- Linux进程间通信——管道(一)
- Mybatis的or逻辑
- ora-123737:instant client light:unsupported server character set zhs16gbk
- java笔试题-> 观察者设计模式2
- Makefile: $^ $^ $@ 与 ..c.o
- linux从零开始学习笔记第二天(共十天)
- 把字符串转换成整数
- DbVisualizer常见问题解答
- 24岁程序猿, 一个人撑起App开发项目
- 编程之注释规范