Tk.mybatis零sql语句实现动态sql查询的方法(4种)
时间:2022-03-10 20:56:33|栏目:JAVA代码|点击: 次
有时候,查询数据需要根据条件使用动态查询,这时候需要使用动态sql,通常我们会自己写动态sql来实现,比如:
<select id="findStudentByCondition" resultType="com.example.service.entity.Student">
SELECT id, name, score FROM tbl_student
<where>
<if test="score !=null and score > 0">
score > #{score}
</if>
<if test="name !=null and name != ''">
<bind name="pattern" value=" '%' + name + '%' "/>
AND name LIKE #{pattern}
</if>
</where>
ORDER BY score DESc
</select>
这个sql是查询成绩大于90并且名字包含“i”的学生信息。但是有时候又加了一个条件,又要去改sql,改入参,有没有一种方式可以将写动态sql像写代码一样实现呢?如果你有这个想法,推荐你了解一下Tk.mybatis。
关于Tk.mybatis的介绍以及如何配置,本文暂不介绍,不了解的请自行百度,本文只介绍如何基于tk.mybatis实现不写sql语句也能实现动态sql查询。
实现方式:
1. 使用Example实现
2. 使用Example.createCriteria
3. 使用Example.builder实现
4. 使用WeekendSqls实现
方式一:使用Example实现
/**
* 第一种:使用example查询
*/
@Test
public void testSelectByExample() {
Example example = new Example(Student.class);
// 设置查询列
example.selectProperties("id","name","score");
// 动态sql
example.and()
.andGreaterThan("score",90)
.andLike("name", "%i%");
// 去重
example.setDistinct(true);
// 排序
example.orderBy("score").desc();
List<Student> students = studentMapper.selectByExample(example);
System.out.println(students);
}
方式二:使用example.createCriteria实现
/**
* 第二种:使用example.createCriteria查询
*/
@Test
public void testSelectByExampleCriteria() {
Example example = new Example(Student.class);
// 设置查询列
example.selectProperties("id","name","score");
// 动态查询
example.createCriteria()
.andGreaterThan("score",90)
.andLike("name", "%i%");
// 去重
example.setDistinct(true);
// 排序
example.orderBy("score").desc();
List<Student> students = studentMapper.selectByExample(example);
System.out.println(students);
}
方式三:使用Example.builder实现
/**
* 第三种:使用Example.builder实现
*/
@Test
public void testSelectByExampleBuilder() {
Example example = Example.builder(Student.class)
// 查询列
.select("id","name","score")
// 动态sql
.where(Sqls.custom()
.andGreaterThan("score",90)
.andLike("name","%i%"))
// 去重
.distinct()
// 排序
.orderByDesc("score")
.build();
List<Student> students = studentMapper.selectByExample(example);
System.out.println(students);
}
方式四:使用weekendSqls实现
/**
* 第四种:使用weekendSqls实现
*/
@Test
public void testSelectByWeekendSqls() {
WeekendSqls<Student> sqls = WeekendSqls.custom();
sqls = sqls
.andGreaterThan(Student::getScore,90)
.andLike(Student::getName,"%i%");
List<Student> sysRoles = studentMapper.selectByExample(Example.builder(Student.class)
.select("id","name","score")
.where(sqls)
.distinct()
.orderByDesc("score")
.build());
System.out.println(sysRoles);
}


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




