Mybatis @select like传值问题是怎样的
Mybatis @select like传值问题
Mybatis @select like传值问题是指在Mybatis中使用@select注解查询数据时,如果传入的参数中包含like关键字,就会出现问题。Mybatis会将like关键字当作一个参数,而不是作为一个查询条件,从而导致查询结果不准确。
Mybatis @select like传值的解决方案
1、使用#{}和${}的区别:#{}会对传入的参数做预处理,而${}不会,所以如果传入的参数中包含like关键字,就应该使用${}而不是#{}。
2、使用PreparedStatement的setString方法:在Mybatis中,可以使用PreparedStatement的setString方法来替换掉传入的like关键字,从而解决Mybatis @select like传值的问题。
3、使用StringUtils的replace方法:在Mybatis中,可以使用StringUtils的replace方法来替换掉传入的like关键字,从而解决Mybatis @select like传值的问题。
Mybatis @select like传值示例代码
@Select("SELECT * FROM table WHERE name LIKE #{name}")
List<User> getUserByName(String name);
//使用PreparedStatement的setString方法
@Select("SELECT * FROM table WHERE name LIKE ?")
List<User> getUserByName(String name);
//使用StringUtils的replace方法
@Select("SELECT * FROM table WHERE name LIKE ${name}")
List<User> getUserByName(@Param("name") String name);
猜您想看
-
如何在Windows系统中定位某个应用程序
在Window...
2023年05月13日 -
为什么我的苹果手机会出现界面卡顿的情况?
苹果手机界面卡...
2023年04月26日 -
怎样解析SparkStreaming和Kafka集成的两收集整收集整理项目中常用到的正则表达式有哪些RR语言R语言可视化中柱形图的美化技巧
1、Spark...
2023年05月26日 -
如何在MySQL中使用ORDER BY?
MySQL中使...
2023年04月15日 -
Javaweb中怎么设置session过期时间
一、什么是se...
2023年05月22日 -
超低功耗解决方案如何赋能Always-on语音交互系统
一、超低功耗解...
2023年05月23日