首页 > 其他分享 >mybatis中${}、 #{}区别及应用场景

mybatis中${}、 #{}区别及应用场景

时间:2022-11-01 11:37:04浏览次数:46  
标签:username 场景 区别 user sql mybatis where select


mybatis中${}、 #{}区别及应用场景

动态sql是mybatis的主要特性之一。在mapper中定义的参数传到xml中之后,在查询之前mybatis会对其进行动态解析。

mybatis提供了两种支持动态sql的语法:#{} 、${}。

select * from t_user where username = '${username}';
select * from t_user where username = #{username};

username传参一致的话,这两种执行的结果是一样的,但是这两种方式在动态sql解析阶段的处理是不一样的。

#{}

#{ }是预编译处理,MyBatis在处理#{ }时,它会将sql中的#{ }替换为?,然后调用PreparedStatement的set方法来赋值,传入字符串后,会在值两边加上单引号

${}

mybatis中${}、 #{}区别及应用场景_表名{ }时,它会将sql中的${ }替换为变量的值,传入的数据不会加两边加上单引号。

这样在预编译之前的sql语句已经不包含变量了,因此可以看出${} 变量的替换阶段是在动态SQL解析阶段。

sql注入

1、注意:使用${ }会导致sql注入,不利于系统的安全性!

如果传入的username 为 a’ or '1=1,那么使用${}处理后直接替换字符串的sql就解析为:

select * from t_user where username = a' or '1=1' ;

这样的话所有的用户数据就被查出来了,这样就属于SQL注入。

如果使用#{},经过sql动态解析和预编译,会把单引号转义为’那么sql最终解析为:

select * from t_user where username = "a\' or \'1=1 ";

这样会查不出任何数据,有效阻止sql注入

有的业务场景经常用到模糊查询,也就是like处理,推荐使用以下处理方式:

t_user.username like #username#

java代码里:

if (!StringUtil.isEmpty(this.username)) {
table.setUsername("%" + this.username + "%");
}

或者也可以使用数据库函数进行连接处理:

select  * from t_user u where username  like CONCAT('%', #username#, '%')

特定场景

注意:以上就可以发现在某些特定场景下只能用${},比如order by 后的排序字段,表名、列名,因为需要替换为不变的常量。如果表名中使用#{}的话,会变成如下:

​select * from #{tablename}-->tablename​​​传参为​​t_user​​​—>处理后变成 ​​select * from 't_user'​​,没有这样的表名,这样的话就会报错了,order by 同理。

性能考虑

因为预编译语句对象可以重复利用,把一个sql预编译后产生的PreparedStatement对象缓存下来,下次对于同一个sql,可以直接使用缓存的PreparedStatement对象,mybatis默认情况下,对所有的sql进行预编译,这样的话**#{}**的处理方式性能会相对高些。

总结

能使用#{}的时候尽量使用#{}
表名、order by的排序字段作为变量时,使用${}


标签:username,场景,区别,user,sql,mybatis,where,select
From: https://blog.51cto.com/u_13351110/5812909

相关文章

  • 线程和进程的区别与联系以及单线程多进程与单进程多线程的区别
    线程和进程概念进程(process):是指具有已一定功能的独立程序,是系统资源分配的基本单位,在内存中有其完备的数据空间和代码空间,拥有完整的虚拟空间地址。一个进程所拥有的数据和......
  • MyBatis零碎知识点
    目录MyBatis简介MyBatis与hibernate区别缓存Hibernate缓存MyBatis缓存对比com.mysql.jdbc.MysqlDataTruncation:Datatruncation:Datatoolongforcolumn‘*’a......
  • sort和sorted区别
    描述sort与sorted区别: sort是应用在list上的方法,属于列表的成员方法,sorted可以对所有可迭代的对象进行排序操作。list的sort方法返回的是对已经存在的列......
  • 007.Mybatis入门
    1.在Mybatis的pom.xml文件中添加依赖<dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><ve......
  • Java-equals和“==”的区别
    “==”是比较运算符,可以用于判断基本数据类型是否相等,当用于判断引用类型的时候,比较的对象的内存地址是否相同equals是Object类当中的方法,不可以用于判断基本数据是否相......
  • &,|与&&,||的区别
    ①&和|既是位运算符也是逻辑运算符,&&和||只是逻辑运算符。②&和|作为位运算符时,先把两侧的数转化为二进制再进行位运算;作为逻辑运算符时,会判断每一个表达式的布尔值。③&......
  • [nrf52] low_power_pwm pwm_library pwm_driver 三者区别
    low_power_pwm使用低功耗定时器,功耗低,一个定时器只能支持2路PWMpwm_library使用硬件定时器,功耗高,一个定时器只能支持2路PWMpwm_driver使用PWM外设模块,功耗中等,一个PWM外......
  • Mybatis动态sql
    通过Mybatis提供的各种标签方法实现动态拼接sql。需求:根据性别和名字查询用户信息。原生sql:SELECTid,username,birthday,sex,addressFROM`user`WHEREsex=1......
  • sudo与su区别
    一、简介两个命令都允许你获得root权限,但是区别在于如何获得root权限。su[选项]...[-][用户[参数]...]su(switchuser的缩写)将身份变成其他用户。当该命令不加任何参数时......
  • 【多服务场景化解决方案】AR虚拟技术助力智能家装
    ​1、介绍 总览本应用采用了华为图形引擎服务的AR虚拟技术,您可以在手机相机里摆放想要购置的家具家电,交互式体验让您可以轻松操控它们的3D图例,以此来确定这些家具家......