mybatis动态排序不生效

博客主要探讨MyBatis动态排序不生效的问题。分析发现,使用#{}方式传参,预编译会对参数加引号,导致数据库无法正常解析order by后的字段。解决办法是将#{}改成${},它是简单字符串替换。同时提醒,${}方式要注意SQL注入风险,需做好参数校验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mybatis动态排序不生效

sql如下:

select * from  table_name order by #{field}

造成问题原因:

mybatis动态参数
#{}方式传参数会使用preparedstatement预编译处理方式,参数是以?占位符的方式传递。可以看到mybaits的sql日志如下:

==> Preparing: SELECT * FROM table_name ORDER BY ?
==> Parameters: time(String)

preparedstatement预编译方式的参数替换的原理1可知预编译方式会对参数加上’'引号,生成的最终sql如下:

SELECT * FROM table_name ORDER BY 'time'

以上sql数据库不能正常解析 order by 后面的字段,这就是我们排序失效的原因

解决办法

将#{}参数方式改成${}参数方式即可。
原因: ${}参数的方式是简单的字符串替换。
在动态解析阶段,该 sql 语句会被解析成:

select * from table_name order by time

总结

  • #{}方式传参数只能处理值参数 不能传递表名,字段等参数
  • ${}字符串替换,可以动态处理表名,字段参数,但是使用这种方式必须注意sql注入的风险,对参数做好校验处理

  1. 备注:preparedstatement具体实现原理见:com.mysql.jdbc.PreparedStatement中的setString方法源码 ↩︎

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值