MyBatis Example And与Or混合使用的实例

网友投稿 370 2022-11-12

MyBatis Example And与Or混合使用的实例

目录MyBatis Example And与Or混合使用(条件1 and 条件2) or ( 条件3 and 条件4)条件1 and (条件2 or 条件3)MyBatis Example 处理And、Or关系方法1.( xx and xx) or ( xx and xx)2.xx and ( xx or xx)

MyBatis Example And与Or混合使用

(条件1 and 条件2) or ( 条件3 and 条件4)

MemberExample example = new MemberExample();

MemberExample.Criteria c1 = example.createCriteria();

c1.andOne(A).andTwo(B);

MemberExample.Criteria c2 = example.createCriteria();

c2.andThree(C).andFour(D);

example.or(c2);

条件1 and (条件2 or 条件3)

思路 : 分拆 : A and ( B or C ) ==> ( A and B ) or ( A and C )

MemberExample example = new MemberExample();

MemberExample.Criteria c1 = example.createCriteria();

c1.andOne(A).andTwo(B);

MemberExample.Criteria c2 = example.createCriteria();

c2.andOne(A).andThree(C);

example.or(c2);

MyBatis Example 处理And、Or关系方法

1.( xx aozVimzTnd xx) or ( xx and xx)

实例代码:

BaUserExample baUserExample = new BaUserExample();

Criteria criteria1 = baUserExample.createCriteria();

criteria1.andOrgIdEqualTo("1");

criteria1.andDeptIdEqualTo("1");

Criteria criteria2 = baUserExample.createCriteria();

criteria2.andUserNameEqualTo("name");

criteria2.andEmailLike("%test@%");

baUserExample.or(criteria2);

userMapper.countByExample(baUserExample);

执行的sql语句:

==> Preparing: select count(*) from ba_user WHERE ( org_id = ? and dept_id = ? ) or( user_name = ? and email like ? )

2.xx and ( xx or xx)

暂时没找到直接的sql语句构造方法,但是经过转换还是可以实现的

根据逻辑表达式可以知道 a and ( b or c ) = ( a and b) or ( a and c )

所以就转变成第一种方法

举个例子,假如想要实现

select count(*) from ba_user WHERE userName like ? and ( dept_id is null or dept_id <>? )

可以转化为

select count(*) from ba_user WHERE (userName like ? and dept_id is null ) or ( userName like ? and dept_id <>? )

实例代码:

BaUserExample baUserExample = new BaUserExample();

Criteria criteria1 = baUserExample.createCriteria();

criteria1.andUserNameLike("%name%");

criteria1.andDeptIdIsNull();

Criteria criteria2 = baUserExample.createCriteria();

criteria2.andUserNameLike("%name%");

criteria2.andDeptIdNotEqualTo("1");

baUserExample.or(criteria2);

userMapper.countByExample(baUserExample);

执行的sql语句:

==> Preparing: select count(*) from ba_user WHERE ( user_name like ? and dept_id is null ) or( user_name like ? and dept_id <> ? )

这算是一种取巧的方法吧,对于这样的问题可以自己编写mapper.xml文件,或者在代码里面过滤,还有一种思路就是修改Criteria的代码实现and和or功能调换(还没尝试过)。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:云计算未来的发展趋势
下一篇:centos7.4安装MFS分布式文件系统
相关文章

 发表评论

暂时没有评论,来抢沙发吧~