Mybatis中foreach标签带来的空格\换行\回车问题及解决方案

网友投稿 870 2023-06-08

Mybatis中foreach标签带来的空格\换行\回车问题及解决方案

Mybatis中foreach标签带来的空格\换行\回车问题及解决方案

原因

在自已做的内容中通过获取多个商品Id,以此来获取多个商品详细信息。但数据库返回的商品信息的顺序与原来List中产品的id顺序并不匹配,这就导致了前端页面商品的信息显示混乱,不匹配。

通过网上找到order by排序可以有效解决这个问题,返回与查询时的产品id顺序一致。还有一点,List时有序的

这里先附带上这个sql语句(只能在数据库中成功)

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()的小伙伴可以自已去查找相关内容

进入主题

如何在Mybatis的XML中写出这样的效果!

select

${prodId}

上面的查询语句返回的输出信息

因为空格,回车与换行的原因这样达不到下面代码的效果instr(',sayx0420,smxj0420,flpd0420,snxj0420',CONCAT(',',prod_id,','))

解决

思路:替换图片内的回车,换行与空格为单引号

ASCII码

char(10) 换行

char(13) 回车

解决:用sql的replace方法去替换

select replace(replace(replace(

${prodId}

,char(13),''),char(10),''),' ' ,'')

再次调用此方法,显示以下结果

附带上源代码

select prod_id, prod_name, price, `describe`, prod_date, prod_pic, integral, Prod_detail

from product_info

where prod_id

#{prodId}

order by

instr(replace(replace(replace(

${prodId}

,char(13),''),char(10),''),' ' ,''),CONCAT(',',`prod_id`,','))

不加Order By排序的结果

结语

用了三个连续的replace方法,可读性差,不美观

虽然解决Fooeach的标签的问题,但还是没能较好的解决开始的问题

如果有想法的小伙伴可以在下面留言告诉我。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java8 Supplier接口和Consumer接口原理解析
下一篇:Spring cache整合redis代码实例
相关文章

 发表评论

暂时没有评论,来抢沙发吧~