MyBatis中#{}和${}的不同和${}的妙用

参考文件:https://blog.csdn.net/alex_81d/article/details/80897621

!!!自己的理解:

$的用法:
1、$不会预编译,会存在sql注入,适用于已知的值

2、如果是基本类型(或者包装类)在使用$的时候,在mapper所在的dao层,必须加上@Param("XXX")或者在mapper.xml的条件中使用#{id}或者#{_parameter},否则会报错

org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'id' in 'class java.lang.Integer'

3、$只会原样输出

 

#号的用法:
1、#会预编译(不是数据库的预编译),可防止注入,适用于用户动态输入的值

2、#,不必在dao层加@Param("XXX")

3、#会在执行的时候,根据参数的类型决定加不加''

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值