Java中 #{}和${}的区别

2023.10.31

#{}:先编译sql语句,再给占位符传值,底层是PreparedStatement实现。可以防止sql注入,比较常用。

${}:先进行sql语句拼接,然后再编译sql语句,底层是Statement实现。存在sql注入现象。只有在需要进行sql语句关键字拼接的情况下才会用到。

考虑一个使用${}的场景:

        假如需要使用mybatis实现批量删除的功能,有两种sql语句可以实现:

  • delete from t_user where id = 1 or id = 2 or id = 3;
  • delete from t_user where id in(1, 2, 3);

这里假设使用第二种,用in的方式。

此时接口的实现类会传来一个参数:ids,代表他想批量删除的一些id,假设传过来的ids为1, 2, 3。此时我们在xml配置文件中写sql语句的时候,如果使用#{}:

<delete id="deleteBatch">
  delete from t_car where id in(#{ids})
</delete>

那么底层会被编译成:

delete from t_user where id in('1,2,3'),显然不能完成需求。

如果使用${}:

<delete id="deleteBatch">
  delete from t_car where id in(${ids})
</delete>

底层会被翻译为:

delete from t_user where id in(1, 2, 3),如此便可以完成需求了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值