- #{}是占位符,预编译处理;${}是拼接符,字符串替换,没有预编译处理。
- Mybatis在处理#{}时,#{}传入参数是以字符串传入,会将SQL中的#{}替换为?号,调用PreparedStatement的set方法来赋值。
- Mybatis在处理时 , 是 原 值 传 入 , 就 是 把 {}时,是原值传入,就是把时,是原值传入,就是把{}替换成变量的值,相当于JDBC中的Statement编译
- 变量替换后,#{} 对应的变量自动加上单引号 '';变量替换后,${} 对应的变量不会加上单引号 ''
- #{} 可以有效的防止SQL注入,提高系统安全性;${} 不能防止SQL 注入
- #{} 的变量替换是在DBMS 中;${} 的变量替换是在 DBMS 外
#{}和${}的区别?
.L.JIN.Jie2024-01-10 6:10
相关推荐
上不如老下不如小10 小时前
Spring整合Mybatis、junit纯注解NiNg_1_23414 小时前
MyBatis和JPA区别详解huang_hai_an20 小时前
MyBatis 写法中國移动丶移不动1 天前
Java 反射与动态代理:实践中的应用与陷阱A阳俊yi1 天前
Mybatis——sql映射文件中的增删查改是小崔啊2 天前
Spring Boot - 数据库集成03 - 集成Mybatissin22013 天前
MyBatis-Plus之常用注解小池先生3 天前
记录让cursor帮我给ruoyi-vue后台管理项目整合mybatis-plus醇氧3 天前
【mybatis】 插件 idea-mybatis-generatorsin22013 天前
MyBatis-Plus的插件