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

最近更新

  1. TCP协议是安全的吗?

    2024-01-11 09:54:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-11 09:54:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-11 09:54:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-11 09:54:02       20 阅读

热门阅读

  1. 【键盘记录器】

    2024-01-11 09:54:02       36 阅读
  2. ThinkPHP6 自定义Excel导出

    2024-01-11 09:54:02       36 阅读
  3. Halcon用共生矩阵计算灰度值特征cooc_feature_matrix

    2024-01-11 09:54:02       37 阅读
  4. 【Kafka每日一问】Kafka重平衡逻辑是什么样的?

    2024-01-11 09:54:02       37 阅读
  5. 宝藏项目记录

    2024-01-11 09:54:02       40 阅读
  6. C语言中各数据类型的大小

    2024-01-11 09:54:02       99 阅读
  7. Qt元对象系统Meta-Object System

    2024-01-11 09:54:02       39 阅读