问题描述:
处理简单分页时,发现从外部传入的排序条件无法生效,但程序无报错,正常返回列表,只是排序条件不对;
原因:
#{}表示一个占位符,当#{}传入的数据是一个字符串时,会自动将传入的数据加一个双引号。
解决方法:
使用${}将传入的数据直接显示生成在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