MyBatis Example And與Or混合使用的實(shí)例
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關(guān)系方法
1.( xx and xx) or ( xx and xx)
實(shí)例代碼:
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語(yǔ)句:
==> Preparing: select count(*) from ba_user WHERE ( org_id = ? and dept_id = ? ) or( user_name = ? and email like ? )
2.xx and ( xx or xx)
暫時(shí)沒找到直接的sql語(yǔ)句構(gòu)造方法,但是經(jīng)過轉(zhuǎn)換還是可以實(shí)現(xiàn)的
根據(jù)邏輯表達(dá)式可以知道 a and ( b or c ) = ( a and b) or ( a and c )
所以就轉(zhuǎn)變成第一種方法
舉個(gè)例子,假如想要實(shí)現(xiàn)
select count(*) from ba_user WHERE userName like ? and ( dept_id is null or dept_id <>? )
可以轉(zhuǎn)化為
select count(*) from ba_user WHERE (userName like ? and dept_id is null ) or ( userName like ? and dept_id <>? )
實(shí)例代碼:
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語(yǔ)句:
==> Preparing: select count(*) from ba_user WHERE ( user_name like ? and dept_id is null ) or( user_name like ? and dept_id <> ? )
這算是一種取巧的方法吧,對(duì)于這樣的問題可以自己編寫mapper.xml文件,或者在代碼里面過濾,還有一種思路就是修改Criteria的代碼實(shí)現(xiàn)and和or功能調(diào)換(還沒嘗試過)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot 普通類調(diào)用Bean對(duì)象的一種方式推薦
這篇文章主要介紹了SpringBoot 普通類調(diào)用Bean對(duì)象的一種方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11springboot開發(fā)擴(kuò)展springmvc實(shí)現(xiàn)解析
這篇文章主要介紹了springboot開發(fā)擴(kuò)展springmvc實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02通過jstack分析解決進(jìn)程死鎖問題實(shí)例代碼
這篇文章主要介紹了通過jstack分析解決進(jìn)程死鎖問題實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01java使用httpclient 發(fā)送請(qǐng)求的示例
HttpClient 是Apache Jakarta Common 下的子項(xiàng)目,可以用來(lái)提供高效的、最新的、功能豐富的支持 HTTP 協(xié)議的客戶端編程工具包,并且它支持 HTTP 協(xié)議最新的版本和建議,這篇文章主要介紹了java使用httpclient 發(fā)送請(qǐng)求的示例,需要的朋友可以參考下2023-10-10