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 <foreach collection="list" open="'," close=",'" separator="," item="prodId" >
${prodId}
</foreach>
上面的查询语句返回的输出信息

因为空格,回车与换行的原因这样达不到下面代码的效果instr(',sayx0420,smxj0420,flpd0420,snxj0420',CONCAT(',',prod_id,','))
解决
思路:替换图片内的回车,换行与空格为单引号
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),''),' ' ,'')
再次调用此方法,显示以下结果

附带上源代码
<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排序的结果

结语
- 用了三个连续的replace方法,可读性差,不美观
- 虽然解决Fooeach的标签的问题,但还是没能较好的解决开始的问题
- 如果有想法的小伙伴可以在下面留言告诉我。
上一篇:IDEA自动生成TestNG的testng.xml的插件方法
栏 目:JAVA代码
下一篇:Java使用Jedis操作Redis服务器的实例代码
本文标题:Mybatis中foreach标签带来的空格\换行\回车问题及解决方案
本文地址:http://www.codeinn.net/misctech/160502.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




