问题描述:
处理简单分页时,发现从外部传入的排序条件无法生效,但程序无报错,正常返回列表,只是排序条件不对;
原因:
#{}表示一个占位符,当#{}传入的数据是一个字符串时,会自动将传入的数据加一个双引号。
解决方法:
使用${}将传入的数据直接显示生成在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、使用${}生成语句是:文章来源:https://www.toymoban.com/news/detail-795716.html
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文章来源地址https://www.toymoban.com/news/detail-795716.html
到了这里,关于Mybatis xml中排序(order by)条件用#{}查询失败的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!