50、Mybatis中#{}和${}的区别是什么

#{}和${}的区别是什么

  • #{}是预编译处理、是占位符,${}是字符串替换、是拼接符。
  • Mybatis 在处理#{}时,会将 sql 中的#{}替换为?号,调用 PreparedStatement 来赋值
  • Mybatis 在处理${}时,就是把${}替换成变量的值,调用 Statement 来赋值
  • #{}的变量替换是在DBMS 中、变量替换后,#{} 对应的变量自动加上单引号
  • ${} 的变量替换是在 DBMS 外、变量替换后,${} 对应的变量不会加上单引号
  • 使用#{}可以有效的防止 SQL 注入, 提高系统安全性。

你可能感兴趣的:(mybatis,java,开发语言,占位符,SQL注入,mysql,数据库)