欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis-Plus實(shí)現(xiàn)條件查詢的三種格式例舉詳解

 更新時(shí)間:2022年08月16日 17:02:55   作者:lxrqiyuan  
本文主要介紹了MyBatis-Plus三中條件查詢格式的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

常規(guī)格式

常規(guī)格式即創(chuàng)建一個(gè)Wrapper的實(shí)現(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中的兩個(gè)參數(shù)分別是數(shù)據(jù)庫中的字段名id,查詢的條件id<5。查詢結(jié)果:

鏈?zhǔn)骄幊谈袷?/h2>

若是多個(gè)條件,即小于多少并且等于多少,那就要用到鏈?zhǔn)骄幊?/p>

		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格式又分為兩種形式。使用時(shí)必須帶上泛型

第一種仍然是使用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ù)來進(jìn)行條件查詢,并不是直接給個(gè)數(shù)據(jù)。

有這么一個(gè)情景:我們都上網(wǎng)買過東西吧,右上角會(huì)有一個(gè)篩選的選項(xiàng),里面會(huì)有接受的最高價(jià)和最低價(jià),我們并不是都會(huì)去填寫這些信息,那么這些數(shù)據(jù)后端獲取的時(shí)候就為空了,這時(shí)候我們就需要判。

當(dāng)然我們可以使用 if 來判斷,但是這樣就不太友好。lt和gt兩個(gè)方法都有兩種不同的重載方法,我們上面使用的是第一種。

  //模擬獲取前端的數(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實(shí)現(xiàn)條件查詢的三種格式例舉詳解的文章就介紹到這了,更多相關(guān)MyBatis-Plus條件查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論