mybatis plus in方法使用詳解
如果是List類(lèi)型的String,例如:List<String>這種類(lèi)型的,就直接放值就可以了,本文講的是當(dāng)你查詢(xún)到的是一個(gè)list集合如何遍歷取值,否則要寫(xiě)sql和接口就顯得很麻煩。
步驟如下:
//查詢(xún)到list集合
List<User> userList = userService.selectById(id);
//結(jié)果集
List<String> resultList = new ArrayList<>();
//遍歷集合取值
userList .forEach(item->{
resultList.add(item.getYouNeedId());
});
//條件構(gòu)造器in上手使用
QueryWrapper<User> qw = new QueryWrapper<>();
qw.in("you_need_id", resultList);
//這里有個(gè)分頁(yè)的查詢(xún),你也可以不用分頁(yè),用mybatisplus里面封裝的其他方法
IPage<User> userIPage = userMapper.selectPage(page, qw);
//返回查詢(xún)結(jié)果,getRecords也是mybatisplus里面封裝的方法
return contractRecordIPage.getRecords();
下面看下Mybatis使用IN語(yǔ)句查詢(xún)
簡(jiǎn)介
在SQL語(yǔ)法中如果我們想使用in的話直接可以像如下一樣使用:
select * from HealthCoupon where useType in ( '4' , '3' )
但是如果在MyBatis中的使用in的話,像如下去做的話,肯定會(huì)報(bào)錯(cuò):
Map<String, Object> selectByUserId(@Param("useType") String useType)
<select id="selectByUserId" resultMap="BaseResultMap" parameterType="java.lang.String">
select * from HealthCoupon where useType in (#{useType,jdbcType=VARCHAR})
</select>
其中useType="2,3";這樣的寫(xiě)法,看似很簡(jiǎn)單,但是MyBatis不支持。。但是MyBatis中提供了foreach語(yǔ)句實(shí)現(xiàn)IN查詢(xún),foreach語(yǔ)法如下:
foreach語(yǔ)句中, collection屬性的參數(shù)類(lèi)型可以使:List、數(shù)組、map集合
collection: 必須跟mapper.java中@Param標(biāo)簽指定的元素名一樣
item: 表示在迭代過(guò)程中每一個(gè)元素的別名,可以隨便起名,但是必須跟元素中的#{}里面的名稱(chēng)一樣。
index:表示在迭代過(guò)程中每次迭代到的位置(下標(biāo))
open:前綴, sql語(yǔ)句中集合都必須用小括號(hào)()括起來(lái)
close:后綴
separator:分隔符,表示迭代時(shí)每個(gè)元素之間以什么分隔
到此這篇關(guān)于mybatis plus in方法使用詳解的文章就介紹到這了,更多相關(guān)mybatis plus in使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring深入分析講解BeanUtils的實(shí)現(xiàn)
java知識(shí)體系統(tǒng)有很多數(shù)據(jù)實(shí)體,比較常用的DTO、BO、DO、VO等,其他類(lèi)似POJO概念太老了現(xiàn)在基本廢棄掉了,本篇幅直接忽略,對(duì)于這幾種數(shù)據(jù)實(shí)體各自代表的含義和應(yīng)用場(chǎng)景先做一下簡(jiǎn)單描述和分析2022-06-06
詳解如何在SpringBoot項(xiàng)目中使用統(tǒng)一返回結(jié)果
在一個(gè)完整的項(xiàng)目中,如果每一個(gè)控制器的方法都返回不同的結(jié)果,那么對(duì)項(xiàng)目的維護(hù)和擴(kuò)展都會(huì)很麻煩。因此,本文為大家準(zhǔn)備了SpringBoot項(xiàng)目中使用統(tǒng)一返回結(jié)果的方法,需要的可以參考一下2022-10-10
spring cloud 使用Zuul 實(shí)現(xiàn)API網(wǎng)關(guān)服務(wù)問(wèn)題
這篇文章主要介紹了spring cloud 使用Zuul 實(shí)現(xiàn)API網(wǎng)關(guān)服務(wù)問(wèn)題,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-05-05
Installij IDEA install或clean項(xiàng)目的使用
這篇文章主要介紹了Installij IDEA install或clean項(xiàng)目的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
Spring Boot 集成Mybatis實(shí)現(xiàn)主從(多數(shù)據(jù)源)分離方案示例
本篇文章主要介紹了Spring Boot 集成Mybatis實(shí)現(xiàn)主從(多數(shù)據(jù)源)分離方案實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-03-03
springboot?vue項(xiàng)目管理前后端實(shí)現(xiàn)編輯功能
這篇文章主要為大家介紹了springboot?vue項(xiàng)目管理前后端實(shí)現(xiàn)編輯功能,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
java自定義ClassLoader加載指定的class文件操作
這篇文章主要介紹了java自定義ClassLoader加載指定的class文件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02

