时间:2021-05-20
原因
在自已做的内容中通过获取多个商品Id,以此来获取多个商品详细信息。但数据库返回的商品信息的顺序与原来List中产品的id顺序并不匹配,这就导致了前端页面商品的信息显示混乱,不匹配。
通过网上找到order by排序可以有效解决这个问题,返回与查询时的产品id顺序一致。还有一点,List时有序的
这里先附带上这个sql语句(只能在数据库中成功)
select prod_id, prod_name, price, `describe`, prod_date, prod_pic, integral, Prod_detail from product_infowhere 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 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排序的结果
结语
到此这篇关于Mybatis中foreach标签带来的空格\换行\回车问题及解决方案的文章就介绍到这了,更多相关Mybatis foreach标签内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
mybatis的foreach标签经常用于遍历集合,构建in条件语句或者批量操作语句。下面是foreach标签的各个属性属性描述collection表示迭代集合
问题描述:在使用MyBatis时,有时需要检查某个记录是否存在数据库中,然后根据其返回的布尔值trueorfalse,来进行逻辑判断。那怎么做呢?解决方案:如检
问题:使用keep-alive标签后部分安卓机返回缓存页位置不精确问题解决方案:constrouter=newRouter({scrollBehavior(to
今天在使用Bootstrap的Tooltip功能时遇到2个小问题:换行丢失,文字不是左对齐。然后经过百度和Bing找到了解决方案。先看一下Bootstrap中展
我们在印刷过程中,可能遇到以下问题,本文将就这些问题进行原因阐释及及解决方案。1、产生原因一:油墨干燥过快。解决方法:减少溶剂量以降低油墨干燥速度;或者把油墨重