当前位置 : 主页 > 数据库 > mysql >

sql中#与$有什么区别

来源:互联网 收集:自由互联 发布时间:2021-08-12
本篇文章给大家介绍一下sql中#与$的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 在这里用到了#{},使用#时: 1、用来传入参数,sql在解析的时候会加上
本篇文章给大家介绍一下sql中#与$的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

在这里用到了#{},使用#时:

1、用来传入参数,sql在解析的时候会加上“”,当成字符串来解析 ,如这里 role_id = “roleid”;

2、#{}能够很大程度上防止sql注入;

延伸:

1、用传入数据直接显示在生成的sql中,如上面的语句,用roleid=传入数据直接显示在生成的sql中,如上面的语句,用roleid={roleId,jdbcType=INTEGER},那么sql在解析的时候值为roleId = roleId,执行时会报错;

2、${}方式无法防止sql注入;

3、$一般用入传入数据库对象,比如数据库表名;

4、能用#{}时尽量用#{};

注意:

mybaties排序时使用order by 动态参数时需要注意,使用${}而不用#{};

相关推荐:《mysql教程》

以上就是sql中#与$有什么区别的详细内容,更多请关注自由互联其它相关文章!

网友评论