码迷,mamicode.com
首页 > 其他好文 > 详细

zbb20180827 Mybatis中#{}和${}有什么区别?

时间:2018-08-27 18:12:32      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:HERE   使用   where   动态   字段   stat   过程   情况下   zha   

1.Mybatis中#{}和${}有什么区别?

(1) #{} 和 ${} 在预编译中的处理是不一样的。#{} 在预处理时,会把参数部分用一个占位符 ? 代替,而${}直接已字符串代替

例如:

select * from tablename where name=#{name}

 

预编译的时候处理成
select * from tablename where name=?

select * from tablename where name=${name}

会在预编译中处理成

select * from tablename where name=‘zhangsan’

 

总结:#{} 的参数替换是发生在 DBMS 中,而 ${} 则发生在动态解析过程中。${}方式会引发SQL注入的问题、同时也会影响SQL语句的预编译,所以从安全性和性能的角度出发,能使用#{}的情况下就不要使用${}

 

但是${}在什么情况下使用呢?

有时候可能需要直接插入一个不做任何修改的字符串到SQL语句中。这时候应该使用${}语法。

比如,动态SQL中的字段名,如:ORDER BY ${columnName}

所以:当使用${}参数作为字段名或表名时,用${}。并需指定statementType为“STATEMENT”

zbb20180827 Mybatis中#{}和${}有什么区别?

标签:HERE   使用   where   动态   字段   stat   过程   情况下   zha   

原文地址:https://www.cnblogs.com/super-admin/p/9542457.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!