mybatis的动态SQL和模糊查询实例详解

网友投稿 328 2023-01-26

mybatis的动态SQL和模糊查询实例详解

现在以一个例子来介绍mybatis的动态SQL和模糊查询:通过多条件查询用户记录,条件为姓名模糊匹配,并且年龄在某两个值之间。

新建表d_user:

create table d_user(

id int primary key auto_increment,

name varchar(10),

age int(3)

);

insert into d_user(name,age) values('Tom',12);

insert into d_user(name,age) values('Bob',13);

insert into d_user(name,age) values('Jack',18);

建表成功:

新建实体类User:

public class User {

private Integer id;

private String name;

private Integer age;

  //getters and setters

  

@Override

public String toString() {

return "User [id=" + id + ", name=" + name + ", age=" + age + "]";

}

public User(Integer id, String name, Integer age) {

super();

this.id = id;

this.name = name;

this.age = age;

}

public User() {

super();

}

}

创建查询条件实体类ConditionUser:

public class ConditionUser {

private String name;

private int minAge;

private int maxAge;

  //getters and setters

  

public ConditionUser(String name, int minAge, int maxAge) {

super();

this.name = name;

this.minAge = minAge;

this.maxAge = maxAge;

}

public ConditionUser() {

super();

}

}

新建映射文件userMapper.xml:

SELECT * FROM d_user WHERE age >= #{minAge} AND age <= #{maxAge}

AND name LIKE CONCAT(CONCbMHzLppOIAT('%',#{name}),'%')

编写测试类:

public class Test {

private SqlSessionFactory sessionFactory;

private SqlSession session;

@Before

public void init(){

//读取配置文件

String resource = "conf.xml";

InputStream is = this.getClass().getClassLoader().getResourceAsStream(resource);

//创建SqlSessionFactory和SqlSession

sessionFactory = new SqlSessionFactoryBuilder().build(is);

session = sessionFactory.openSession();

}

@After

public void free(){

session.commit();

session.close();

}

@org.junit.Test

public void getUser() {

String statement = "com.mybatis.test7.userMapper"+".getUser";

ConditionUser conditionUser = new ConditionUser("o", 13, 18);

List list = session.selectList(statement, conditionUser);

System.out.println(list);

}

}

运行结果:

注意:

1. 在配置文件中编写sql语句时,为防止大于号和小于号在表示大小关系和表示标签符号之间产生混淆,所以通常用&gt;和&lt;来代替sql语句中大于号和小于号。

2. 在SQL语句中添加动态SQL标签if的原因是,当在后台获取的name属性值为null时,防止生成where name like %null%的条件判断语句,正确的逻辑应该是,当传来的name属性值为null时,取消此筛选条件,即不使用where name like ?的判断条件。在mybatis中,可用的动态SQL标签有:if,choose(when,otherwise),trim(where,set),foreach。

3. 在使用模糊查询时,拼接%+#{name}+%的方法有如下几种:

(1).像上述例子中一样,在SQL语句中使用CONCAT关键字。

(2).使用${}代替#{}:

SELECT * FROM d_user WHERE age >= #{minAge} AND age <= #{maxAge}

AND name LIKE '%${name}%'

注意,默认情况下,使用#{}语法,MyBatis会产生PreparedStatement语句,并且安全地设置PreparedStatement参数,这个过程中MyBatis会进行必要的安全检查和转义。例如:

执行SQL:select * from emp where name = #{employeeName}

参数:employeeName=>Smith

解析后执行的SQL:select * from emp where name = ?

执行SQL:Select * from emp where name = ${employeeName}

参数:employeeName传入值为:Smith

解析后执行的SQL:Select * from emp where name =Smith

综上所述,${}方式可能会引发SQL注入的问题,同时也会影响SQL语句的预编译,所以从安全性和性能的角度出发,应尽量使用#{}。当需要直接插入一个不做任何修改的字符串到SQL语句中,例如在ORDER BY后接一个不添加引号的值作为列名,这时候就需要使用${}。

(3).在程序中拼接。

总结

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot自定义注解实现Token校验的方法
下一篇:pi币开放api接口(pi币支付平台)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~