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
原文地址:https://blog.csdn.net/xianglingchuan/article/details/135515821
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!