Mybatis中foreach標(biāo)簽帶來的空格\換行\(zhòng)回車問題及解決方案
原因
在自已做的內(nèi)容中通過獲取多個(gè)商品Id,以此來獲取多個(gè)商品詳細(xì)信息。但數(shù)據(jù)庫返回的商品信息的順序與原來List中產(chǎn)品的id順序并不匹配,這就導(dǎo)致了前端頁面商品的信息顯示混亂,不匹配。
通過網(wǎng)上找到order by排序可以有效解決這個(gè)問題,返回與查詢時(shí)的產(chǎn)品id順序一致。還有一點(diǎn),List時(shí)有序的
這里先附帶上這個(gè)sql語句(只能在數(shù)據(jù)庫中成功)
select prod_id, prod_name, price, `describe`, prod_date, prod_pic, integral, Prod_detail from product_info where prod_id in('sayx0420','smxj0420','flpd0420','snxj0420' ) order by instr(',sayx0420,smxj0420,flpd0420,snxj0420',CONCAT(',',prod_id,','))
想了解instr()的小伙伴可以自已去查找相關(guān)內(nèi)容
進(jìn)入主題
如何在Mybatis的XML中寫出這樣的效果!
select <foreach collection="list" open="'," close=",'" separator="," item="prodId" > ${prodId} </foreach>
上面的查詢語句返回的輸出信息
因?yàn)?mark>空格,回車與換行的原因這樣達(dá)不到下面代碼的效果instr(',sayx0420,smxj0420,flpd0420,snxj0420',CONCAT(',',prod_id,','))
解決
思路:替換圖片內(nèi)的回車,換行與空格為單引號(hào)
ASCII碼
char(10) 換行
char(13) 回車
解決:用sql的replace方法去替換
select replace(replace(replace( <foreach collection="list" open="'," close=",'" separator="," item="prodId" > ${prodId} </foreach>,char(13),''),char(10),''),' ' ,'')
再次調(diào)用此方法,顯示以下結(jié)果
附帶上源代碼
<select id="selectByProdIds" resultMap="BaseResultMap" parameterType="java.util.List"> select prod_id, prod_name, price, `describe`, prod_date, prod_pic, integral, Prod_detail from product_info where prod_id <foreach collection="list" separator="," open="in(" close=")" item="prodId"> #{prodId} </foreach> order by instr(replace(replace(replace( <foreach collection="list" open="'," close=",'" separator="," item="prodId" > ${prodId} </foreach>,char(13),''),char(10),''),' ' ,''),CONCAT(',',`prod_id`,',')) </select>
不加Order By排序的結(jié)果
結(jié)語
- 用了三個(gè)連續(xù)的replace方法,可讀性差,不美觀
- 雖然解決Fooeach的標(biāo)簽的問題,但還是沒能較好的解決開始的問題
- 如果有想法的小伙伴可以在下面留言告訴我。
到此這篇關(guān)于Mybatis中foreach標(biāo)簽帶來的空格\換行\(zhòng)回車問題及解決方案的文章就介紹到這了,更多相關(guān)Mybatis foreach標(biāo)簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java Swing實(shí)現(xiàn)簡單的體重指數(shù)(BMI)計(jì)算器功能示例
這篇文章主要介紹了Java Swing實(shí)現(xiàn)簡單的體重指數(shù)(BMI)計(jì)算器功能,涉及Java Swing窗口組件布局、響應(yīng)及數(shù)值運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2017-12-12Spring Security中successHandler和failureHandler使用方式
這篇文章主要介紹了Spring Security中successHandler和failureHandler使用方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Spring?Boot集成RabbitMQ以及隊(duì)列模式操作
RabbitMQ是實(shí)現(xiàn)AMQP(高級(jí)消息隊(duì)列協(xié)議)的消息中間件的一種,下面這篇文章主要給大家介紹了關(guān)于Spring?Boot集成RabbitMQ以及隊(duì)列模式操作的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04spring為java.util.Properties類型的屬性進(jìn)行賦值過程解析
這篇文章主要介紹了spring為java.util.Properties類型的屬性進(jìn)行賦值過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01Java下載遠(yuǎn)程服務(wù)器文件到本地(基于http協(xié)議和ssh2協(xié)議)
這篇文章主要介紹了Java下載遠(yuǎn)程服務(wù)器文件到本地的方法(基于http協(xié)議和ssh2協(xié)議),幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2021-01-01