Tk.mybatis零sql语句实现动态sql查询的方法(4种)
短信预约 -IT技能 免费直播动态提醒
有时候,查询数据需要根据条件使用动态查询,这时候需要使用动态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实现
@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实现
@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实现
@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实现
@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);
}
到此这篇关于Tk.mybatis零sql语句实现动态sql查询的方法(4种)的文章就介绍到这了,更多相关Tk.mybatis 动态sql查询内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341