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

本文详细解析了Mybatis中#{}

a、#{}是预编译处理,${}是字符串替换。

b、Mybatis 在处理#{}时,会将 sql 中的#{}替换为?号,调用 PreparedStatement 的 set 方法来赋值;
c、Mybatis 在处理时,就是把{}时,就是把{}替换成变量的值。
d、使用#{}可以有效的防止 SQL 注入,提高系统安全性。

### MyBatis中#$区别及实际开发中的选择策略 #### 1. #$的基本概念 在MyBatis中,`#``$`是两种不同的参数替换方式。`#{}`会被MyBatis处理为一个占位符,实际SQL会变为带有`?`的形式,并且参数值会被绑定到占位符上[^4]。这种方式可以有效防止SQL注入攻击。而`${}`则是直接将变量的值插入到SQL语句中,不会进行任何转义或预处理[^1]。 #### 2. 安全性对比 使用`#{}`时,MyBatis会生成PreparedStatement中的占位符`?`,并设置相应的参数值。这种方式是安全的,因为它可以有效防止SQL注入攻击[^5]。例如: ```sql <select id="getUserById" parameterType="int" resultType="User"> SELECT * FROM users WHERE id = #{id} </select> ``` 上述代码中,`#{id}`会被替换为`?`,并且`id`的值会被安全地绑定到SQL语句中。 相比之下,`${}`会直接将变量的值插入到SQL语句中,不经过任何转义处理。这种方式存在SQL注入的风险,因此需要谨慎使用[^2]。例如: ```sql <select id="getUsersByOrder" parameterType="map" resultType="User"> SELECT * FROM users ORDER BY ${orderColumn} </select> ``` 如果`orderColumn`的值是由用户输入的,则可能会导致SQL注入攻击[^3]。 #### 3. 使用场景对比 - **`#{}`的适用场景**:适用于所有类型的参数,包括基本数据类型、字符串、集合、对象等。它适合用于需要传递动态参数但不需要直接拼接SQL的场景。 - **`${}`的适用场景**:适用于需要动态拼接SQL的场景,例如表名、列名或排序字段等。由于其安全性较低,必须确保传入的值是可信的,避免SQL注入风险。 #### 4. 性能对比 从性能角度来看,`#{}``${}`没有本质区别。但由于`#{}`通过PreparedStatement实现,数据库可以缓存执行计划,因此在多次执行相同SQL时,`#{}`可能会稍微优于`${}`[^4]。 #### 5. 实际开发中的选择策略 在实际开发中,应优先使用`#{}`以确保SQL的安全性。只有在确实需要动态拼接SQL(如表名、列名)时才使用`${}`,并且必须对传入的值进行严格的校验过滤[^3]。例如: ```sql <select id="dynamicTableQuery" parameterType="map" resultType="User"> SELECT * FROM ${tableName} WHERE id = #{id} </select> ``` 上述代码中,`tableName`的值必须是经过验证的可信值,而`id`则通过`#{}`安全地绑定到SQL语句中[^2]。 #### 注意事项 - 在使用`${}`时,务必确保传入的值是可控的,避免因用户输入导致的安全问题。 - 对于复杂的SQL查询,可以结合使用`<if>``<where>`等动态SQL标签,减少直接拼接SQL的需求[^1]。 ### 示例代码 以下是一个结合`#{}``${}`的示例: ```sql <select id="queryUsers" parameterType="map" resultType="User"> SELECT * FROM ${tableName} <where> <if test="name != null"> AND name = #{name} </if> <if test="age != null"> AND age = #{age} </if> </where> ORDER BY ${orderBy} </select> ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值