mybatis中$ 和#的区别


  这是我的sql ,需要动态的插入表名。  当用# 的时候就会报一个异常 :如下

          这是因为 #号  能把你传入的值自动加上引号    不能充当sql中的字段名 等之类使用   ,这样可以防止sql注入   因为传入的值不会参与sql语法的编译 。

          而用$就不会报错了  ,因为用它传入的值 会进行sql的语法编译 ,

          所以$不能有效的防止sql注入  ,不是很安全  ,所以能用#的时候就不要用$,


          一般在order by  和 from(表名)这里用$

         

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值