MyBatis中正則使用foreach拼接字符串
正則使用foreach拼接字符串
業(yè)務(wù)需求:使用代理名字查詢?cè)摯淼乃邢录?jí)代理
數(shù)據(jù)庫(kù):
pid存儲(chǔ)的是該字段的上級(jí)集合
實(shí)現(xiàn)步驟:
1、先用名字在用戶表中查詢出用戶id集合
2、在數(shù)據(jù)庫(kù)中判斷字段pids中是否出現(xiàn)這些id,再去重
-------上重點(diǎn)-------:
在mybatis中寫拼接這個(gè)sql碰到了很多坑,記錄下這個(gè)教訓(xùn):
1、foreach拼接字符串,開(kāi)頭和結(jié)尾用單引號(hào),否則報(bào)錯(cuò)
2、中括號(hào)使用轉(zhuǎn)義符,否則查詢結(jié)果不正確
3、${item}不能用#,否則報(bào)錯(cuò)
4、使用replace函數(shù)去空格,否則查詢不到結(jié)果(mybatis自動(dòng)給我加上了空格)
foreach標(biāo)簽拼接多字段in ,和union
mybatis for標(biāo)簽 手寫肯定是不可能,復(fù)制又經(jīng)常忘記哪里有,記錄一下復(fù)制方便
(oracle數(shù)據(jù)庫(kù))
批量添加 ,修改 ,拼接(xx,xx)in , union
添加,修改:
<foreach item="list" index="index" collection="list" open="begin" close="end;"> INSERT INTO XXX( xxx ) VALUES( #{list.XXX,jdbcType=VARCHAR}, #{xxx} //值不在list對(duì)象里,需要在mapper上加@param注解 ); </foreach>
(字段,字段) in :
(<foreach collection="paramList" index="index" item="item" open="(字段,字段,字段) in(" separator="," close=")"> <if test="index%900==0">(#{item.XX},#{item.XX},#{item.XXX})) or (XX,XX,XX) in(</if> (#{item.XX},#{item.XX},#{item.XX}) < /foreach> )
注意拼接in時(shí) 要用()包住for標(biāo)簽
union: select a.xx xx from( ?? ?<foreach collection="query.list" item="item" separator="union all"> ? ? select list.XX ? ? from XXX ?list ? ? <where> ? ? ??? ?list.XX= #{item}? ? ??? ? ?< if test="query.xx!= null and query.xx!= ''"> ? ? ? ? and list.xx= #{query.xx} ? ?? ? ?< /if> ? ? < /where> ? ? </foreach> ? ? ) a ? ? ?order by a.xx
mysql數(shù)據(jù)庫(kù):
使用批量添加修改的時(shí)候需要在數(shù)據(jù)庫(kù)地址加上: allowMultiQueries=true
url: jdbc:mysql://192.xxx.xx.xx:xxxx/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&allowMultiQueries=true
刪除重復(fù)數(shù)據(jù)保留最大的id
select * FROM ?? ?table AS ta WHERE ?? ?ta.id <> ( SELECT ?? ?t.maxid FROM ?? ?( SELECT max( tb.id ) AS maxid FROM table AS tb WHERE ta.job_id = tb.job_id ) t ?? ?);
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java去除空格、標(biāo)點(diǎn)符號(hào)的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于java去除空格、標(biāo)點(diǎn)符號(hào)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09基于javaweb+jsp的游泳館會(huì)員管理系統(tǒng)(附源碼)
這篇文章主要介紹了基于javaweb+jsp的游泳館會(huì)員管理系統(tǒng),開(kāi)發(fā)工具eclipse/idea/myeclipse/sts等均可配置運(yùn)行,此源代碼社和課程設(shè)計(jì),大作業(yè)及畢業(yè)設(shè)計(jì)項(xiàng)目,需要的朋友可以參考下2022-04-04Spring Security驗(yàn)證流程剖析及自定義驗(yàn)證方法
Spring Security是一個(gè)能夠?yàn)榛赟pring的企業(yè)應(yīng)用系統(tǒng)提供聲明式的安全訪問(wèn)控制解決方案的安全框架。這篇文章主要介紹了Spring Security驗(yàn)證流程剖析及自定義驗(yàn)證方法,需要的朋友可以參考下2018-03-03SpringBoot使用@PostConstruct注解導(dǎo)入配置方式
這篇文章主要介紹了SpringBoot使用@PostConstruct注解導(dǎo)入配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11JAVA JNI原理詳細(xì)介紹及簡(jiǎn)單實(shí)例代碼
這篇文章主要介紹了JAVA JNI原理的相關(guān)資料,這里提供簡(jiǎn)單實(shí)例代碼,需要的朋友可以參考下2016-12-12一篇文章告訴你如何在Java數(shù)組中插入一個(gè)字符
本篇文章主要介紹了Java數(shù)組中插入一個(gè)字符的相關(guān)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-10-10java正則表達(dá)式對(duì)特殊字符的轉(zhuǎn)義以及異?,F(xiàn)象
這篇文章主要給大家介紹了關(guān)于java正則表達(dá)式對(duì)特殊字符的轉(zhuǎn)義以及異常現(xiàn)象的相關(guān)資料,在Java中使用正則表達(dá)式匹配特殊字符也需要使用轉(zhuǎn)義字符"\",需要的朋友可以參考下2023-06-06