MyBatis-Plus實現(xiàn)條件查詢的三種格式例舉詳解
常規(guī)格式
常規(guī)格式即創(chuàng)建一個Wrapper的實現(xiàn)類QueryWrapper對象,將其傳給selectList方法內(nèi)部
QueryWrapper qw = new QueryWrapper();
//lt是小于,id小于5
qw.lt("id",5);
List<User> users = userDao.selectList(qw);
System.out.println(users);
qw中的兩個參數(shù)分別是數(shù)據(jù)庫中的字段名id,查詢的條件id<5。查詢結(jié)果:

鏈式編程格式
若是多個條件,即小于多少并且等于多少,那就要用到鏈式編程
QueryWrapper qw = new QueryWrapper();
//大于2小于5
qw.lt("id",5).gt("id",2);
List<User> users = userDao.selectList(qw);
System.out.println(users);
查詢結(jié)果為:

lambda格式(推薦)
lambda格式又分為兩種形式。使用時必須帶上泛型
第一種仍然是使用QueryWrapper的對象
QueryWrapper<User> qw = new QueryWrapper<User>(); //lt是小于,id小于5 qw.lambda().lt(User::getId,5); List<User> users = userDao.selectList(qw); System.out.println(users);
第二種就是直接使用LambdaQueryWrapper
LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>(); //2-5,即3,4 lqw.lt(User::getId,5).gt(User::getId,2); //上面是并且,下面是或 //lqw.lt(User::getId,2).or().gt(User::getId,5); List<User> users = userDao.selectList(lqw); System.out.println(users);
條件查詢null判定
你有沒有想過為什么需要null判定?我們后端都是接收前端傳來的數(shù)據(jù)來進行條件查詢,并不是直接給個數(shù)據(jù)。
有這么一個情景:我們都上網(wǎng)買過東西吧,右上角會有一個篩選的選項,里面會有接受的最高價和最低價,我們并不是都會去填寫這些信息,那么這些數(shù)據(jù)后端獲取的時候就為空了,這時候我們就需要判。
當然我們可以使用 if 來判斷,但是這樣就不太友好。lt和gt兩個方法都有兩種不同的重載方法,我們上面使用的是第一種。
//模擬獲取前端的數(shù)據(jù)
//UserQuery是User的繼承類,這樣既可以模仿id的上下限
UserQuery uq = new UserQuery();
uq.setId(7);
uq.setId2(3);
LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>();
lqw.lt(null!=uq.getId(),User::getId, uq.getId())
.gt(null!=uq.getId2(),User::getId, uq.getId2());
List<User> users = userDao.selectList(lqw);
System.out.println(users);最終結(jié)果:

到此這篇關(guān)于MyBatis-Plus實現(xiàn)條件查詢的三種格式例舉詳解的文章就介紹到這了,更多相關(guān)MyBatis-Plus條件查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot在filter中如何用threadlocal存放用戶身份信息
這篇文章主要介紹了springboot中在filter中如何用threadlocal存放用戶身份信息,本文章主要描述通過springboot的filter類,在過濾器中設(shè)置jwt信息進行身份信息保存的方法,需要的朋友可以參考下2024-07-07
記一次線上SpringCloud Feign請求服務(wù)超時異常排查問題
這篇文章主要介紹了記一次線上SpringCloud Feign請求服務(wù)超時異常排查問題,本項目與下游項目均注冊在Eureka上面,對這個1秒就超時感到很迷惑,于是開始查閱底層源碼之旅。需要的朋友可以參考下2022-01-01
SpringBoot中使用spring-retry 解決失敗重試調(diào)用
本文主要介紹了SpringBoot中使用spring-retry 解決失敗重試調(diào)用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07

