Mybatis中foreach標(biāo)簽帶來的空格換行回車問題及解決方案
原因
在自已做的內(nèi)容中通過獲取多個商品Id,以此來獲取多個商品詳細(xì)信息。但數(shù)據(jù)庫返回的商品信息的順序與原來List中產(chǎn)品的id順序并不匹配,這就導(dǎo)致了前端頁面商品的信息顯示混亂,不匹配。通過網(wǎng)上找到order by排序可以有效解決這個問題,返回與查詢時的產(chǎn)品id順序一致。還有一點(diǎn),List時有序的
這里先附帶上這個sql語句(只能在數(shù)據(jù)庫中成功)
select prod_id, prod_name, price, `describe`, prod_date, prod_pic, integral, Prod_detail from product_infowhere 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)榭崭?回車與換行的原因這樣達(dá)不到下面代碼的效果instr(’,sayx0420,smxj0420,flpd0420,snxj0420’,CONCAT(’,’,prod_id,’,’))
解決
思路:替換圖片內(nèi)的回車,換行與空格為單引號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 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é)語
用了三個連續(xù)的replace方法,可讀性差,不美觀 雖然解決Fooeach的標(biāo)簽的問題,但還是沒能較好的解決開始的問題 如果有想法的小伙伴可以在下面留言告訴我。到此這篇關(guān)于Mybatis中foreach標(biāo)簽帶來的空格換行回車問題及解決方案的文章就介紹到這了,更多相關(guān)Mybatis foreach標(biāo)簽內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. MYSQL(電話號碼,身份證)數(shù)據(jù)脫敏的實(shí)現(xiàn)2. Mysql入門系列:MYSQL服務(wù)器內(nèi)部安全性-安全數(shù)據(jù)目錄訪問3. SQLite3的綁定函數(shù)族使用與其注意事項(xiàng)詳解4. ACCESS 調(diào)用后臺存儲過程的實(shí)現(xiàn)方法5. Oracles XMLDB Study NOTE (2)6. MySql遠(yuǎn)程連接的實(shí)現(xiàn)方法7. Mysql InnoDB的鎖定機(jī)制實(shí)例詳解9. Access中批量替換數(shù)據(jù)庫內(nèi)容的兩種方法10. 如何實(shí)現(xiàn)MySQL數(shù)據(jù)庫的備份與恢復(fù)
