Mybatis如何使用正則模糊匹配多個(gè)數(shù)據(jù)
使用正則模糊匹配多個(gè)數(shù)據(jù)
背景
有這樣一個(gè)需求,需要模糊匹配一個(gè)List<String>的所有元素,如果采用LIKE則需要寫很多個(gè)語(yǔ)句,這時(shí)候其實(shí)可以采用正則匹配
mybaits正則匹配
Mysql模糊匹配姓名為a、b、c的所有學(xué)生
select * from table where name REGEXP 'a|b|c'
那么用mybatis怎么寫呢?我們第一時(shí)間可能會(huì)這樣寫:
<select id="selectAll" resultMap="BaseResultMap" parameterType="java.util.List">
?? ?select *
?? ?from student
?? ?where name REGEXP
?? ?<foreach collection="list" item="item" open="'" close="'" separator="|">
? ??? ??? ? #{item}
?? ?</foreach>
</select>但這樣是錯(cuò)誤的,因?yàn)榉g成sql,語(yǔ)句是
select * from student where name REGEXP ' ? | ? | ? '
不能在SQL語(yǔ)句中使用占位符?
正確的SQL應(yīng)該是以下兩種:
select * from student where name REGEXP ?
select * from student where name REGEXP CONCAT_WS('|',?,?,?)對(duì)于前一個(gè)來說,占位符的數(shù)據(jù)應(yīng)該在Java代碼中拼接完成;對(duì)于后面一個(gè),CONCAT_WS的參數(shù)應(yīng)該在foreach標(biāo)簽中完成
<select id="selectAll" resultMap="BaseResultMap" parameterType="java.util.List">
?? ?select *
?? ?from student
?? ?where name REGEXP CONCAT_WS('|',
? ? <foreach collection="list" item="item" open="" close="" separator=",">
? ? ? ? #{item}
? ? </foreach>
?? ?)
</select>Mybatis多字段模糊匹配同一個(gè)值
CityDAO
? ? List<Map<String, Object>> findByMap(Map<String, Object>map); ? ? List<Map<String, Object>> findByMap2(Map<String, Object>map);
XML
使用concat將多個(gè)字段拼接之后在進(jìn)行模糊查詢,相比第一種更推薦第二種,執(zhí)行效率更好
? <select id="findByMap" resultType="java.util.Map">
? ? ? ? SELECT id,pid as pIDDD,city_name,type FROM city
? ? ? ? WHERE 1=1
? ? ? ? <if test="keyWord != null and keyWord != ''">
? ? ? ? ? ? AND pid LIKE concat('%',#{keyWord},'%')
? ? ? ? ? ? OR city_name LIKE concat('%',#{keyWord},'%')
? ? ? ? ? ? OR type LIKE concat('%',#{keyWord},'%')
? ? ? ? </if>
? ? </select>
? ? <select id="findByMap2" resultType="java.util.Map">
? ? ? ? SELECT id,pid as pIDDD,city_name,type FROM city
? ? ? ? WHERE 1=1
? ? ? ? <if test="keyWord != null and keyWord != ''">
? ? ? ? ? ? AND CONCAT(IFNULL(pid,''),IFNULL(city_name,''),IFNULL(type,'')) LIKE concat('%',#{keyWord},'%')
? ? ? ? </if>
? ? </select>特別提醒:由于CONCAT中只要有一個(gè)為NULL,則會(huì)返回NULL,這將導(dǎo)致你查不到正確數(shù)據(jù)。為了確保不為NULL,使用 IFNULL判斷下就可以了
IFNULL() 函數(shù)用于判斷第一個(gè)表達(dá)式是否為 NULL,如果為 NULL 則返回第二個(gè)參數(shù)的值,如果不為 NULL 則返回第一個(gè)參數(shù)的值。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringMVC結(jié)構(gòu)簡(jiǎn)介及常用注解匯總
這篇文章主要介紹了SpringMVC結(jié)構(gòu)簡(jiǎn)介及常用注解匯總,幫助大家更好的理解和學(xué)習(xí)使用SpringMVC,感興趣的朋友可以了解下2021-03-03
聊聊SpringCloud和SpringCloudAlibaba的區(qū)別
這篇文章主要介紹了SpringCloud和SpringCloudAlibaba的區(qū)別,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
Java設(shè)計(jì)模式之備忘錄模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院
我們?cè)诰幊痰臅r(shí)候,經(jīng)常需要保存對(duì)象的中間狀態(tài),當(dāng)需要的時(shí)候,可以恢復(fù)到這個(gè)狀態(tài)。接下來通過本文給大家分享java設(shè)計(jì)模式之備忘錄模式,感興趣的的朋友一起看看吧2017-08-08
SpringBoot自定義Redis實(shí)現(xiàn)緩存序列化詳解
Spring提供了一個(gè)RedisTemplate來進(jìn)行對(duì)Redis的操作,但是RedisTemplate默認(rèn)配置的是使用Java本機(jī)序列化。如果要對(duì)對(duì)象操作,就不是那么的方便。所以本文為大家介紹了另一種SpringBoot結(jié)合Redis實(shí)現(xiàn)序列化的方法,需要的可以參考一下2022-07-07
Java volatile如何實(shí)現(xiàn)禁止指令重排
這篇文章主要介紹了Java volatile如何實(shí)現(xiàn)禁止指令重排,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
Eureka源碼閱讀解析Server服務(wù)端啟動(dòng)流程實(shí)例
這篇文章主要為大家介紹了Eureka源碼閱讀解析Server服務(wù)端啟動(dòng)流程實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
詳解Java實(shí)現(xiàn)負(fù)載均衡的幾種算法代碼
本篇文章主要介紹了詳解Java實(shí)現(xiàn)負(fù)載均衡的幾種算法代碼 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
Spring打包jar包時(shí)jsp頁(yè)面無法訪問問題解決
這篇文章主要介紹了Spring打包jar包時(shí)jsp頁(yè)面無法訪問問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
Spring配置文件解析之BeanDefinitionReader詳解
這篇文章主要介紹了Spring配置文件解析之BeanDefinitionReader詳解,ApplicationContext.xml配置文件解析成Document對(duì)象,真正對(duì)xml中元素解析的類是在BeanDefinitionDocumentReader的實(shí)現(xiàn)類中來完成的,需要的朋友可以參考下2024-02-02
簡(jiǎn)單了解SpringCloud運(yùn)行原理
這篇文章主要介紹了簡(jiǎn)單了解SpringCloud運(yùn)行原理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11

