#{}和${}的区别

#{} 和 ${}的区别,如何在实际应用中使用

在平常写mybatis的动态SQL语句时,大多使用的是#{} 。至于${} ,没用过,也不知道是什么。实际大多数情景下,我们使用的也都是#{},很少有场景会用到${}

1.两者的区别

  • #{}:使用的是预编译,对应JBDC中的PreparedStatement
  • ${}:mybatis不会修改或者转义字符换,直接输出变量值

2.实际应用

举例:

select * from mytab order by #{sortType}

在这条SQL语句中,

我的意图是:排序的字段不固定,所以需要动态参数,因此下意识使用了#{}。

结果:SQL语句正确执行,但是排序功能异常。

打印Mybatis的SQL日志:

select * from mytab order by ?
order_id

实际执行的SQL语句:

select * from mytab order by 'order_id'

结论:使用#{}时,具体的SQL语句的参数会加上单引号,这也是导致排序失效的原因。

那么如果使用${}时什么效果?

select * from mytab order by ${sortType}

打印Mybatis的SQL日志:

select * from mytab order by order_id

**结论:**可以看出,${}中的参数是以实际值来拼接的SQL语句,而不是参数形式。

3.分析

为什么大多数的时候,我们使用的是#{}?

这里就要提到SQL注入的问题,#{}是以参数的形式,实际的SQL语句为参数值加单引号 ,从而避免了SQL注入的问题。

${}直接输出参数值,mybatis不做转义,可能引发SQL注入问题。

4.应该如何使用?

正常情况下,我们在写MyBatis的动态SQL语句时,大都是使用在条件查询参数,如where order_id = #{id},所以不会有什么问题。但是在我们在遇到上面的例子时,我们就不能再使用#{},可以选择使用${},但是由此引发的SQL注入问题如何解决?

如何解决在使用${}时引发的SQL注入?

答案很简答,入参时做参数校验,类似order by 后面的字段虽然是动态的,但也是有范围的,都是表中的字段,所以可以使用枚举类做检查。

5.我的收获!

理论+实践 = 会用

  • 6
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值