mybatis#号和$区别

MyBatis中,`#{}`${}都是用于实现动态SQL的占位符,但它们在使用场景和安全性上有明显的区别:

  1. 用途区别

    • #{}主要用于传递接口传输过来的具体数据,如参数值,它可以防止SQL注入,因为MyBatis会对#{}中的参数进行预编译处理,将参数值安全地传递给数据库,并且自动转义特殊字符,避免SQL注入攻击。这种方式适用于大多数情况,尤其是当参数值来自用户输入或不可信数据时。例如: SELECT * FROM users WHERE id = #{userId}

      java 复制代码
          "#{}":MyBatis会使用预编译的SQL语句,并为每个参数,设置相应的占位符(通常是"?"),
          
          然后,当执行SQL时,MyBatis会使用 "PreparedStatement 的 setXXX()方法"来设置参数值,
          
          这种方式,可以有效地防止SQL注入攻击,
      
          因为,参数值不会被解析为SQL的一部分。
    • ${}则一般用于传入数据库对象,例如列表和表名,它不会对参数进行预编译处理,而是直接将参数拼接 到了原始的SQL里面。这种方式可以适合应用在一些动态SQL场景中,比如动态传递表名、动态设置排序字段等,但由于不会对参数进行特殊处理,存在SQL注入的风险。

      sql 复制代码
      SELECT * FROM users WHERE id = ${userId} 
      相当于 "SELECT * FROM users WHERE id =" + userId
  2. 安全性

    • #{}由于具有更高的安全性,能够防止SQL注入,因此在能够使用#{}的地方应尽量避免使用${}。使用#{}产生的预编译SQL语句可以提高数据库性能,因为数据库可以缓存相同的预编译语句。
    • ${}由于直接拼接原始SQL语句,无法防止SQL注入的问题,因此在需要动态参数的场景中应谨慎使用,确保传入的数据是安全的。
  3. 总结

    • 在实际应用中,应优先考虑使用#{}占位符来传递参数,以避免潜在的安全风险。只有在确实需要动态拼接原始SQL语句的情况下,才考虑使用${}占位符,并确保传入的数据经过适当的验证和过滤。
相关推荐
淘矿人10 分钟前
2026年4月-DeepSeek V4 vs GPT-5.5深度对比测评:weelinking一键切换实测
服务器·数据库·人工智能·python·gpt·学习·php
2401_8314194428 分钟前
CSS 悬停箭头闪烁下移问题的根源与稳定解决方案
jvm·数据库·python
reasonsummer38 分钟前
【教学类-160-11】20260419 AI视频培训-练习011“豆包AI视频《佛源植语》+豆包图片风格:无(关键词:藏传唐卡)”
数据库·音视频·豆包
瀚高PG实验室1 小时前
pgroonga全文检索插件的BUG
数据库·postgresql·bug·瀚高数据库
Rick19931 小时前
mysql 慢查询如何快速定位
数据库·mysql
2401_833033621 小时前
c++如何实现简单的文件签名验证_HMAC-SHA1算法应用【进阶】
jvm·数据库·python
qq_392690661 小时前
SQL报表查询标准规范_SQL书写规范优化
jvm·数据库·python
Vect__1 小时前
MySQL的数据类型和约束
android·数据库·mysql
八秒记忆的老男孩1 小时前
Sentinel5P的L1B级数据预处理(BD7和BD8)【20260427】
数据库·redis·缓存
ChoSeitaku1 小时前
5.MySQL表的约束|空属性|默认值|列描述|主键|自增长|唯一键|外键
android·数据库·mysql