栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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),''),' ' ,'')

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

附带上源代码

不加Order By排序的结果

结语

  • 用了三个连续的replace方法,可读性差,不美观
  • 虽然解决Fooeach的标签的问题,但还是没能较好的解决开始的问题
  • 如果有想法的小伙伴可以在下面留言告诉我。

到此这篇关于Mybatis中foreach标签带来的空格换行回车问题及解决方案的文章就介绍到这了,更多相关Mybatis foreach标签内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/134267.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号