MyBatis 中,#{} 和 ${}的区别

1. 底层处理机制不同

  • #{}(预编译占位符) :采用预处理的方式执行 SQL。它会将传入的参数替换为 ? 占位符,并在数据库端进行预编译。MyBatis 会根据参数的数据类型自动进行处理,比如字符串类型会自动加上单引号,数字类型则直接传入。
  • ${}(字符串直接替换):仅仅是在内存中进行纯粹的字符串拼接,直接将参数原样输出到 SQL 语句中,不会做任何类型的转换或自动添加引号。如果传入的是字符串且没有手动加单引号,就会因为不符合 SQL 语法而报错。

2.安全性不同(最关键的区别)

  • #{} :由于采用了预编译机制,参数值会被当作纯粹的"数据"而不是"SQL 指令"来解析,因此能够有效防止 SQL 注入攻击,安全性极高。
  • ${} :因为是直接拼接字符串,如果用户传入了恶意的 SQL 关键字(例如 OR 1=1),这些内容会被数据库当作合法的 SQL 指令执行,从而改变原始 SQL 的逻辑,存在极大的 SQL 注入风险

3.使用场景不同

  • #{} :适用于绝大多数常规的数据传递场景,如 WHERE id = #{id}INSERT INTO user(name) VALUES(#{name}) 等。
  • ${} :仅适用于需要动态生成 SQL 结构的特殊场景。比如你需要动态指定表名(SELECT * FROM ${tableName})、动态排序字段或方向(ORDER BY price ${sort})。因为这些是 SQL 命令或关键字,如果用 #{} 加上单引号变成了字符串,就会导致 SQL 语法错误。
相关推荐
mqiqe9 小时前
面试题-MyBatis 面试篇
java·面试·mybatis
kuonyuma10 小时前
MyBatis入门·注解操作
java·spring boot·mysql·spring·mybatis
SuperArc19991 天前
SpringBoot+Slf4j+Log4j2+mybatis 日志整合
spring boot·mybatis·log4j2·slf4j·日志整合
可乐ea1 天前
【Spring Boot + MyBatis|第4篇】MyBatis 动态 SQL:if、where、foreach 使用详解
java·spring boot·后端·sql·mybatis
一条泥憨鱼2 天前
苍穹外卖【day5|Redis与店铺营业状态设置】
java·后端·mybatis·苍穹外卖
来杯@Java2 天前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
我是唐青枫2 天前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis
碎碎念_4924 天前
SpringBoot和MyBatis框架·速通版
spring boot·后端·mybatis
唐青枫4 天前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis