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

 更新时间:2020年04月28日 14:13:18   作者:ddh19980820  
这篇文章主要介绍了解决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>

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

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的标签的问题,但还是没能较好的解决开始的问题
  • 如果有想法的小伙伴可以在下面留言告诉我。

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

相关文章

  • 详解Spring Cloud Zuul中路由配置细节

    详解Spring Cloud Zuul中路由配置细节

    本篇文章主要介绍了详解Spring Cloud Zuul中路由配置细节,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • Java 数据结构之时间复杂度与空间复杂度详解

    Java 数据结构之时间复杂度与空间复杂度详解

    算法复杂度分为时间复杂度和空间复杂度。其作用: 时间复杂度是度量算法执行的时间长短;而空间复杂度是度量算法所需存储空间的大小
    2021-11-11
  • IDEA 2019.2.2配置Maven3.6.2打开Maven项目出现 Unable to import Maven project的问题

    IDEA 2019.2.2配置Maven3.6.2打开Maven项目出现 Unable to import Maven

    这篇文章主要介绍了IDEA 2019.2.2配置Maven3.6.2打开Maven项目出现 Unable to import Maven project的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • java定时任务框架elasticjob详解

    java定时任务框架elasticjob详解

    这篇文章主要介绍了java定时任务框架elasticjob详解,Elastic-Job是ddframe中dd-job的作业模块中分离出来的分布式弹性作业框架。该项目基于成熟的开源产品Quartz和Zookeeper及其客户端Curator进行二次开发。,需要的朋友可以参考下
    2019-06-06
  • Java中TreeSet、HashSet、Collection重写比较器的实现

    Java中TreeSet、HashSet、Collection重写比较器的实现

    比较器是一种可以对集合或数组中的元素按照自定义的方式进行排序的对象,本文主要介绍了Java中TreeSet、HashSet、Collection重写比较器的实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2023-08-08
  • Java生成独一无二的工单号实例

    Java生成独一无二的工单号实例

    这篇文章主要介绍了Java生成独一无二的工单号实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-09-09
  • BeanUtils.copyProperties使用总结以及注意事项说明

    BeanUtils.copyProperties使用总结以及注意事项说明

    这篇文章主要介绍了BeanUtils.copyProperties使用总结以及注意事项说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • 微服务 Spring Boot 整合 Redis BitMap 实现 签到与统计功能

    微服务 Spring Boot 整合 Redis BitMap 实现 签到与统计功能

    这篇文章主要介绍了微服务 Spring Boot 整合 Redis BitMap 实现 签到与统计功能,文章简单介绍了Redis BitMap 基本用法结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • 一个合格JAVA软件工程师应该具备什么

    一个合格JAVA软件工程师应该具备什么

    一个合格JAVA软件工程师应该具备哪些专业技能,面试技巧是什么?本文为大家分享了2016版最新Java软件工程师就业思维图,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • Java线程池的优点及池化技术的应用

    Java线程池的优点及池化技术的应用

    这篇文章主要介绍了Java线程池的优点及池化技术的应用,Java种提高程序的执行效率有两种实现方法,一个是使用线程、另一个是使用线程池,下文我们就来具体介绍该详细内容吧,需要的小伙伴可以参考一下
    2022-05-05

最新评论