zbb20180827 Mybatis中#{}和${}有什么区别?
Posted Daryll
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了zbb20180827 Mybatis中#{}和${}有什么区别?相关的知识,希望对你有一定的参考价值。
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中#{}和${}有什么区别?的主要内容,如果未能解决你的问题,请参考以下文章
zbb20171215 MyBatis报错: Parameter '*' not found. Available parameters are [1, 0, param1, para