mybatis in查詢傳入String方式
mybatis in查詢傳入String
在使用 mybaits 進(jìn)行 in 查詢時(shí),傳入String,如1,2,3,發(fā)現(xiàn)查詢的結(jié)果并非我們想要的
這是因?yàn)?{}編譯完自動(dòng)加雙引號(hào)“” 也就是變成in (“1,2,3”)
如果想要獲得我們想要的結(jié)果,可以使用${},編譯完是這樣的 in (1,2,3)
例如,查詢鈴音庫(kù)中多首鈴音的總數(shù)量
<select id="getProgsResourceCount" resultType="java.lang.Long"
parameterType="com.progandresource.entity.ProgsResourceCond">
select count(ring_no)
from progandresmanage_ringinfo where valid_day > now()
<if test="ringNo != '' and ringNo != null">
and ring_no in (${ringNo})
</if>
</select>
如果傳入?yún)?shù)是List或者Array,則直接用foreach即可
例如
<select id="getProgsResourceCount" resultType="java.lang.Long" parameterType="java.util.List">
select count(ring_no)
from progandresmanage_ringinfo where valid_day > now() and ring_no in
<foreach collection="list" item="item" index="index" open="(" close=")" separator=",">
#{item, jdbcType=VARCHAR}
</foreach>
</select>
mybatis in查詢傳入字符串參數(shù)
sql里的in操作符允許我們?cè)趙here子句中規(guī)定多個(gè)值進(jìn)行匹配。
語(yǔ)法:
SELECT column_name(s) FROM table_name WHERE column_name IN (value1,value2,...);
在mybatis里,可以通過(guò)傳入數(shù)組或容器(array、list、set、map)通過(guò)foreach標(biāo)簽來(lái)給in操作符指定參數(shù)。
問(wèn)題:想要從org表中匹配字段org_id在OR001、OR002、OR004中的數(shù)據(jù),org_id是字符串類型的字段。
常規(guī)方法是在mapper.java中傳入一個(gè)包含"OR001"、“OR002”、"OR004"的list對(duì)象orgIdList,在xml中:
SELECT * from org where org_id in
<foreach item="orgId" index="index" collection="orgIdList" open="(" close=")" separator=",">
#{orgId}
</foreach>
如果要作為in的匹配參數(shù)的多個(gè)值在一個(gè)String類型的對(duì)象orgs中,想直接通過(guò)String傳入,有兩種實(shí)現(xiàn)方式。
1、在xml中用${orgs}把整個(gè)String作為sql的一部分
SELECT * from org where org_id in (${orgs})
這種寫法需要關(guān)注字符串orgs的內(nèi)容在拼入之后,整個(gè)sql是否是符合語(yǔ)法的,按上面的需求和sql寫法,就要求作為sql一部分的orgs的值為"‘OR001',‘OR002',‘OR004'"。
參數(shù)直接以sql一部分的方式作為查詢語(yǔ)句存在sql注入的風(fēng)險(xiǎn),有一些項(xiàng)目可能會(huì)一刀切地限制開發(fā)者不允許用這種寫法。
2、在xml的foreach標(biāo)簽里,傳入collection屬性時(shí)將字符串用split函數(shù)轉(zhuǎn)為數(shù)組
SELECT * from org where org_id in
<foreach item="orgId" index="index" collection="orgs.split(',')" open="(" close=")" separator=",">
#{orgId}
</foreach>
在這里傳入的orgs字符串的值可以為"OR001,OR002,OR004",在調(diào)用split函數(shù)時(shí)設(shè)置","分格,可以直接切分出三個(gè)字符串作為數(shù)組的元素。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring?Boot?Reactor?整合?Resilience4j詳析
這篇文章主要介紹了Spring?Boot?Reactor整合Resilience4j詳析,文章通過(guò)引入pom包展開詳細(xì)介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-09-09
spring hibernate實(shí)現(xiàn)動(dòng)態(tài)替換表名(分表)的方法
下面小編就為大家?guī)?lái)一篇spring hibernate實(shí)現(xiàn)動(dòng)態(tài)替換表名(分表)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08
阿里巴巴 Sentinel + InfluxDB + Chronograf 實(shí)現(xiàn)監(jiān)控大屏
這篇文章主要介紹了阿里巴巴 Sentinel + InfluxDB + Chronograf 實(shí)現(xiàn)監(jiān)控大屏,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09

