MybatisPlus特殊查詢(xún)的實(shí)現(xiàn)介紹
一.查詢(xún)投影
查詢(xún)投影又稱(chēng)查詢(xún)指定字段
@Test
void testGetAll07(){
LambdaQueryWrapper<Users> lqw = new LambdaQueryWrapper<Users>();
lqw.select(Users::getId,Users::getName,Users::getAge);
List<Users> userList = userDao.selectList(lqw);
System.out.println(userList);
}
比如下面查詢(xún)的結(jié)果就隱藏了password、tel字段

二.聚合查詢(xún)
使用通過(guò)MP使用聚合函數(shù)進(jìn)行查詢(xún)
@SpringBootTest
class Mybatisplus{
@Autowired
private UserDao userDao;
@Test
void testGetAll(){
QueryWrapper<User> lqw = new QueryWrapper<User>();
//lqw.select("count(*) as count");
//SELECT count(*) as count FROM user
//lqw.select("max(age) as maxAge");
//SELECT max(age) as maxAge FROM user
//lqw.select("min(age) as minAge");
//SELECT min(age) as minAge FROM user
//lqw.select("sum(age) as sumAge");
//SELECT sum(age) as sumAge FROM user
lqw.select("avg(age) as avgAge");
//SELECT avg(age) as avgAge FROM user
List<Map<String, Object>> userList = userDao.selectMaps(lqw);
System.out.println(userList);
}
}

為了在做結(jié)果封裝的時(shí)候能夠更簡(jiǎn)單,我們將上面的聚合函數(shù)都起了個(gè)名稱(chēng),方面后期來(lái)獲取這些數(shù)據(jù)
三.分組查詢(xún)
分組查詢(xún),完成 group by的查詢(xún)使用
@SpringBootTest
class Mybatisplus{
@Autowired
private UserDao userDao;
@Test
void testGetAll09(){
QueryWrapper<Users> lqw = new QueryWrapper<Users>();
lqw.select("count(*) as count,age");
lqw.groupBy("age");
List<Map<String, Object>> list = userDao.selectMaps(lqw);
System.out.println(list);
}
}
groupBy為分組,最終的sql語(yǔ)句為:
SELECT count(*) as count,age FROM users GROUP BY age

注:
聚合與分組查詢(xún),無(wú)法使用lambda表達(dá)式來(lái)完成
MP只是對(duì)MyBatis的增強(qiáng),如果MP實(shí)現(xiàn)不了,我們可以直接在DAO接口中使用MyBatis的方式實(shí)現(xiàn)
四.查詢(xún)條件
4.1 等值查詢(xún)
根據(jù)用戶(hù)名和密碼查詢(xún)用戶(hù)信息
@SpringBootTest
class Mybatisplus{
@Autowired
private UserDao userDao;
@Test
void testGetAll13(){
LambdaQueryWrapper<Users> lqw = new LambdaQueryWrapper<Users>();
lqw.eq(Users::getName, "懶羊羊").eq(Users::getPassword, "123456");
Users users = userDao.selectOne(lqw);
System.out.println(users);
}
}
eq(): 相當(dāng)于 =,對(duì)應(yīng)的sql語(yǔ)句為
SELECT id,name,password,age,tel FROM user WHERE (name = ? AND password = ?)

selectList:查詢(xún)結(jié)果為多個(gè)或者單個(gè)
selectOne:查詢(xún)結(jié)果為單個(gè)
4.2 范圍查詢(xún)
對(duì)年齡進(jìn)行范圍查詢(xún),使用lt()、le()、gt()、ge()、between()進(jìn)行范圍查詢(xún)
@SpringBootTest
class Mybatisplus{
@Autowired
private UserDao userDao;
@Test
void testGetAll12(){
LambdaQueryWrapper<Users> lqw = new LambdaQueryWrapper<Users>();
lqw.between(Users::getAge, 10, 30);
List<Users> userList = userDao.selectList(lqw);
System.out.println(userList);
}
}與之對(duì)應(yīng)的SQL為:
SELECT id,name,password,age,tel FROM user WHERE (age BETWEEN ? AND ?)

4.3 模糊查詢(xún)
查詢(xún)表中name屬性的值包含‘美’字的用戶(hù)信息,使用like進(jìn)行模糊查詢(xún)
@SpringBootTest
class Mybatisplus {
@Autowired
private UserDao userDao;
@Test
void testGetAll10(){
LambdaQueryWrapper<Users> lqw = new LambdaQueryWrapper<Users>();
lqw.like(Users::getName, "美");
List<Users> userList = userDao.selectList(lqw);
System.out.println(userList);
}
}
最后也是通過(guò)一個(gè)字查到了美羊羊

對(duì)應(yīng)的SQL為:
SELECT id,name,password,age,tel FROM user WHERE (name LIKE ?)
- like():前后加百分號(hào),如 %美%
- likeLeft():前面加百分號(hào),如 %美
- likeRight():后面加百分號(hào),如 美%
4.4 排序查詢(xún)
查詢(xún)所有數(shù)據(jù),然后按照id降序
@SpringBootTest
class Mybatisplus{
@Autowired
private UserDao userDao;
@Test
void testGetAll11(){
LambdaQueryWrapper<Users> lwq = new LambdaQueryWrapper<>();
lwq.orderBy(true,true, Users::getId);
List<Users> users = userDao.selectList(lwq);
System.out.println(users);
}
}
查詢(xún)結(jié)果如下:

condition :條件,返回boolean,當(dāng)condition為true,進(jìn)行排序,如果為false,則不排序
isAsc:是否為升序,true為升序,false為降序
columns:需要操作的列

除了上面演示的這種實(shí)現(xiàn)方式,還有很多其他的排序方法可以被調(diào)用
- orderByAsc/Desc(單個(gè)column):按照指定字段進(jìn)行升序/降序
- orderByAsc/Desc(多個(gè)column):按照多個(gè)字段進(jìn)行升序/降序
- orderByAsc/Desc * condition:條件,true添加排序,false不添加排序 * 多個(gè)columns:按照多個(gè)字段進(jìn)行排序
到此這篇關(guān)于MybatisPlus特殊查詢(xún)的實(shí)現(xiàn)介紹的文章就介紹到這了,更多相關(guān)MybatisPlus特殊查詢(xún)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
鎖超時(shí)發(fā)現(xiàn)parallelStream并行流線(xiàn)程上下文坑解決
這篇文章主要為大家介紹了鎖超時(shí)發(fā)現(xiàn)parallelStream并行流線(xiàn)程上下文坑解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
Java注解中@Component和@Bean的區(qū)別
這篇文章主要介紹了@Component和@Bean的區(qū)別,在這給大家簡(jiǎn)單介紹下作用對(duì)象不同:@Component 注解作用于類(lèi),而 @Bean 注解作用于方法,具體實(shí)例代碼參考下本文2024-03-03
Java實(shí)現(xiàn)特定范圍的完數(shù)輸出算法示例
這篇文章主要介紹了Java實(shí)現(xiàn)特定范圍的完數(shù)輸出算法,簡(jiǎn)單說(shuō)明了完數(shù)的概念、計(jì)算原理并結(jié)合實(shí)例形式分析了java針對(duì)給定范圍內(nèi)的完數(shù)輸出操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-12-12
在spring中實(shí)例化bean無(wú)效的問(wèn)題
這篇文章主要介紹了在spring中實(shí)例化bean無(wú)效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
如何解決java獲取時(shí)間相差8小時(shí)的問(wèn)題
最近使用new date()獲取的時(shí)間會(huì)和真實(shí)的本地時(shí)間相差8小時(shí)。本文就詳細(xì)的來(lái)介紹一下解決java獲取時(shí)間相差8小時(shí)的問(wèn)題,感興趣的可以了解一下2021-09-09
詳解在SpringBoot應(yīng)用中獲取應(yīng)用上下文方法
本篇文章主要介紹了詳解在SpringBoot應(yīng)用中獲取應(yīng)用上下文方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-04-04
SpringBoot mybatis 實(shí)現(xiàn)多級(jí)樹(shù)形菜單的示例代碼
這篇文章主要介紹了SpringBoot mybatis 實(shí)現(xiàn)多級(jí)樹(shù)形菜單的示例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05

