首页 > 开发 > 综合 > 正文

mybatis中#和$传参的区别

2024-07-21 02:52:42
字体:
来源:转载
供稿:网友

#{a} 会按照类型替换, 如果a 是string, 那么最后的结果为‘ssss’ a是文本替换,如果a是String,那么最后的结果也为ssss,{}主要用在**group by, order by 后面 具体来讲一下吧:**

使用#传入参数是,sql语句解析是会加上"",比如 select * from table where name = #{name} ,传入的name为小李,那么最后打印出来的就是select * from table where name = ‘小李',就是会当成字符串来解析,这样相比于$的好处是比较明显对的吧,#{}传参能防止sql注入,如果你传入的参数为 单引号',那么如果使用${},这种方式 那么是会报错的,另外一种场景是,如果你要做动态的排序,比如 order by column,这个时候务必要用${},因为如果你使用了#{},那么打印出来的将会是select * from table order by 'name' ,这样是没用***也即是说能用#就不用$*****那么他们的区别也很明显了**1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成sql时的值为order by "111", 如果传入的值是id,则解析成的sql为order by "id".2. $将传入的数据直接显示生成在sql中。如:order by $user_id$,如果传入的值是111,那么解析成sql时的值为order by user_id, 如果传入的值是id,则解析成的sql为order by id.3. #方式能够很大程度防止sql注入。 4.$方式无法防止Sql注入。5.$方式一般用于传入数据库对象,例如传入表名. 6.一般能用#的就别用$.MyBatis排序时使用order by 动态参数时需要注意,用$而不是#

因为这里写$的时候总是比显示,估计是我的技术不精,所以直接用代码片进行显示了


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表