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

所属分类: 软件编程 / java 阅读数: 2289
收藏 0 赞 0 分享

原因

在自已做的内容中通过获取多个商品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>

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

one

因为空格,回车与换行的原因这样达不到下面代码的效果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排序的结果

mysql图片

结语

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

Spring boot将配置属性注入到bean类中

本篇文章主要介绍了Spring boot将配置属性注入到bean类中,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Java正则判断日期格式是否正确的方法示例

这篇文章主要介绍了Java正则判断日期格式是否正确的方法,结合实例形式分析了Java针对日期字符串正则判断的相关操作技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

java Future 接口使用方法详解

这篇文章主要介绍了java Future 接口使用方法详解,Future接口是Java线程Future模式的实现,可以来进行异步计算的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java 读取外部资源的方法详解及实例代码

这篇文章主要介绍了Java 读取外部资源的方法详解及实例代码的相关资料,经常有读取外部资源的要求,如配置文件等等需要读取,需要的朋友可以参考下
收藏 0 赞 0 分享

Java正则表达式之split()方法实例详解

这篇文章主要介绍了Java正则表达式之split()方法,结合实例形式较为详细的分析了split方法的功能、使用方法及相关注意事项,需要的朋友可以参考下
收藏 0 赞 0 分享

Java 存储模型和共享对象详解

这篇文章主要介绍了Java 存储模型和共享对象详解的相关资料,对Java存储模型,可见性和安全发布的问题是起源于Java的存储结构及共享对象安全,需要的朋友可以参考下
收藏 0 赞 0 分享

Java使用正则表达式实现找出数字功能示例

这篇文章主要介绍了Java使用正则表达式实现找出数字功能,结合实例形式分析了Java针对数字的匹配查找及非数字替换操作相关实现技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

Spring核心IoC和AOP的理解

本文主要介绍了Spring核心IoC和AOP的相关知识。具有很好的参考价值,下面跟着小编一起来看下吧
收藏 0 赞 0 分享

详解Spring AOP 拦截器的基本实现

本篇文章主要介绍了详解Spring AOP 拦截器的基本实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Mybatis 中的一对一,一对多,多对多的配置原则示例代码

这篇文章主要介绍了 Mybatis 中的一对一,一对多,多对多的配置原则示例代码,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多