码迷,mamicode.com
首页 > 其他好文 > 详细

MyBatis正在爬的坑

时间:2018-06-20 14:39:42      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:处理   结果   串处理   就是   rom   记录   开始   为什么   sql   

换了份工作,开始接触Mybatis,开一篇文章记录一下自己遇到的坑

2018-06-20
今天遇到了一个问题,编好的sql语句在数据库可以执行但是写到程序里边就GG,什么问题呢?一直纠结在程序哪里写错了,找的快要死了!!!

select t.* from table_B where t.usr_id in (#{userIds})

sql语句就是如上这句话,参数是经过处理的原参数为(XXX,YYY,OOO)类似模式,处理之后(‘XXX‘,‘YYY‘,‘OOO‘)

报错为什么呢?想通了很简单,想不通很难受

仅仅是因为系统会将你传进来的 参数作为一个字符串处理,等同于(" ‘XXX‘,‘YYY‘,‘OOO‘ ") (添加空格纯粹是为了看的更清楚)

原sql语句就会变成select t.* from table_B where t.usr_id in (" ‘XXX‘,‘YYY‘,‘OOO‘ ")

你的理想sql语句为:select t.* from table_B where t.usr_id in ( ‘XXX‘,‘YYY‘,‘OOO‘ )

SO,你不会得到任何返回结果,而sql语句在数据库的执行是没有丝毫问题的

MyBatis正在爬的坑

标签:处理   结果   串处理   就是   rom   记录   开始   为什么   sql   

原文地址:https://www.cnblogs.com/gosun/p/9203190.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!