MyBatis Example And與Or混合使用的實例
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 and 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);
執(zhí)行的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);
執(zhí)行的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功能調換(還沒嘗試過)。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
springboot開發(fā)擴展springmvc實現解析
這篇文章主要介紹了springboot開發(fā)擴展springmvc實現解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-02-02

