欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis中foreach標簽帶來的空格\換行\(zhòng)回車問題及解決方案

 更新時間:2020年04月28日 14:13:18   作者:ddh19980820  
這篇文章主要介紹了解決Mybatis中foreach標簽帶來的空格,換行,回車問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

原因

在自已做的內(nèi)容中通過獲取多個商品Id,以此來獲取多個商品詳細信息。但數(shù)據(jù)庫返回的商品信息的順序與原來List中產(chǎn)品的id順序并不匹配,這就導(dǎo)致了前端頁面商品的信息顯示混亂,不匹配。
通過網(wǎng)上找到order by排序可以有效解決這個問題,返回與查詢時的產(chǎn)品id順序一致。還有一點,List時有序的

這里先附帶上這個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)容

進入主題

如何在Mybatis的XML中寫出這樣的效果!

select <foreach collection="list" open="'," close=",'" separator="," item="prodId" >
${prodId}
</foreach>

上面的查詢語句返回的輸出信息

one

因為空格,回車與換行的原因這樣達不到下面代碼的效果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é)果

結(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>

完整結(jié)果

不加Order By排序的結(jié)果

mysql圖片

結(jié)語

  • 用了三個連續(xù)的replace方法,可讀性差,不美觀
  • 雖然解決Fooeach的標簽的問題,但還是沒能較好的解決開始的問題
  • 如果有想法的小伙伴可以在下面留言告訴我。

到此這篇關(guān)于Mybatis中foreach標簽帶來的空格\換行\(zhòng)回車問題及解決方案的文章就介紹到這了,更多相關(guān)Mybatis foreach標簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java Swing實現(xiàn)簡單的體重指數(shù)(BMI)計算器功能示例

    Java Swing實現(xiàn)簡單的體重指數(shù)(BMI)計算器功能示例

    這篇文章主要介紹了Java Swing實現(xiàn)簡單的體重指數(shù)(BMI)計算器功能,涉及Java Swing窗口組件布局、響應(yīng)及數(shù)值運算相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • Spring Boot啟動端口修改方法

    Spring Boot啟動端口修改方法

    spring boot是個好東西,可以不用容器直接在main方法中啟動,而且無需配置文件,方便快速搭建環(huán)境。下面通過本文給大家分享Spring Boot修改啟動端口的方法,感興趣的的朋友一起看看吧
    2017-07-07
  • Java中的this和super實例淺析

    Java中的this和super實例淺析

    要說this和super就不得不說Java的封裝和繼承了。這篇文章主要介紹了Java中的this和super實例淺析,需要的朋友可以參考下
    2017-03-03
  • Spring Security中successHandler和failureHandler使用方式

    Spring Security中successHandler和failureHandler使用方式

    這篇文章主要介紹了Spring Security中successHandler和failureHandler使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Java多線程基礎(chǔ)

    Java多線程基礎(chǔ)

    這篇文章主要介紹Java多線程基礎(chǔ),線程是進程的一個實體,是CPU調(diào)度和分派的基本單位,它是比進程更小的能獨立運行的基本單位,多線程指在單個程序中可以同時運行多個不同的線程執(zhí)行不同的任務(wù),下面來學(xué)習(xí)具體的詳細內(nèi)容
    2021-10-10
  • Spring?Boot集成RabbitMQ以及隊列模式操作

    Spring?Boot集成RabbitMQ以及隊列模式操作

    RabbitMQ是實現(xiàn)AMQP(高級消息隊列協(xié)議)的消息中間件的一種,下面這篇文章主要給大家介紹了關(guān)于Spring?Boot集成RabbitMQ以及隊列模式操作的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • spring為java.util.Properties類型的屬性進行賦值過程解析

    spring為java.util.Properties類型的屬性進行賦值過程解析

    這篇文章主要介紹了spring為java.util.Properties類型的屬性進行賦值過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • Java多線程同步工具類CyclicBarrier的使用

    Java多線程同步工具類CyclicBarrier的使用

    本文主要介紹了Java多線程同步工具類CyclicBarrier的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Java下載遠程服務(wù)器文件到本地(基于http協(xié)議和ssh2協(xié)議)

    Java下載遠程服務(wù)器文件到本地(基于http協(xié)議和ssh2協(xié)議)

    這篇文章主要介紹了Java下載遠程服務(wù)器文件到本地的方法(基于http協(xié)議和ssh2協(xié)議),幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2021-01-01
  • springboot下配置多數(shù)據(jù)源的方法

    springboot下配置多數(shù)據(jù)源的方法

    本篇文章主要介紹了springboot下配置多數(shù)據(jù)源的方法,具有一定的參考價值,有興趣的可以了解一下
    2017-04-04

最新評論