Mybatis xml中排序(order by)条件用#{}查询失败

问题描述:

处理简单分页时,发现从外部传入的排序条件无法生效,但程序无报错,正常返回列表,只是排序条件不对;

原因:

#{}表示一个占位符,当#{}传入的数据是一个字符串时,会自动将传入的数据加一个双引号。

解决方法:

使用${}将传入的数据直接显示生成在sql中;

1、当查询语句使用#{},例如传入"update_date desc"排序条件,生成语句如下

复制代码
select id, title, name, status, create_by,create_date,update_by,update_date from table 
WHERE status = 1 order by "update_date desc"

2、使用${}生成语句是:

复制代码
select id, title, name, status, create_by,create_date,update_by,update_date from table 
WHERE status = 1 order by update_date desc

3、推荐文章

Mybatis中${}和#{}的区别:https://blog.csdn.net/BBQ__ZXB/article/details/127089187

相关推荐
码农幻想梦42 分钟前
实验三 Mybatis多表查询操作
mybatis
cab51 小时前
MyBatis如何处理数据库中的JSON字段
数据库·json·mybatis
小北方城市网2 小时前
SpringBoot 安全认证实战(Spring Security + JWT):打造无状态安全接口体系
数据库·spring boot·后端·安全·spring·mybatis·restful
Z_W_H_2 小时前
MyBatis-Plus 详细学习文档
学习·mybatis
程序员侠客行4 小时前
Mybatis插件原理及分页插件
java·后端·架构·mybatis
qqqahhh21 小时前
xml文件的动态化配置,导入
xml·spring·springboot
吴声子夜歌1 天前
Maven——pom.xml详解
xml·java·maven
一嘴一个橘子1 天前
mybatis - 多表映射(对一映射、对多映射)
java·mybatis
子沫20202 天前
使用mybatis-plus、mybatis插入数据库时加密,查询数据库时解密,自定义TypeHandler 加解密使用
数据库·mybatis·mybatis-plus
w***76552 天前
存储技术全景:从基础原理到未来趋势
spring boot·后端·mybatis