亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis中正則使用foreach拼接字符串

 更新時(shí)間:2022年01月14日 08:40:06   作者:weixin_42620197  
這篇文章主要介紹了MyBatis中正則使用foreach拼接字符串,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

正則使用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)文章

最新評(píng)論