一、什么是动态 SQL
我们打开 MyBatis 3 官网的文档:https://mybatis.org/mybatis-3/zh/dynamic-sql.html,一边看官网一边去说
我们之前在学习 JDBC 时,好比碰到条件查询,我们需要用 Java 代码去判断,然后再进行 SQL 的拼接,有的时候多一个逗号或者是多一个逗号,都会导致我们的 SQL 的错误。
可以说是非常的痛苦,但是好在 MyBatis 给我们解决了这个问题,我们可以使用 MyBatis 的动态 SQL,让 MyBatis 帮助我们完成这些麻烦的操作。
二、动态 SQL 有那些
之前版本的 MyBatis 中,是有大量的元素(也就是标签)需要去学习,之后,在 MyBatis 3 中,它替换了之前大部分的元素,大大简化元素种类,我们来看看现在还有那些元素
1. if 标签
if 标签可以说是我们之后经常会使用到的一个标签,它里面有一个属性,就是 test。test 里面就是写的判断。
这也就是说,我们可以将之前写在 Java 中的判断,现在可以通过 if 标签,直接和 SQL 语句写在一起了,我们现在来看例子。
我们就用之前的例子,然后修改一下传入的参数。
然后我们开始进行测试~~~
默认情况下是可以全部查询出来,我们现在给他传递一个名称
然后我们来写 xml,如果名称不为空,我们就按照名称进行模糊查询。
这里我们判断好之后,然后进行拼接,我们用传递和不传递值进行测试,看看效果。
可以看到,同样的一个方法,通过动态 SQL 之后,我们就可以实现多种类型的查询了,当然,现在就一个 name,但是后面可以再加。
2. choose、when、otherwise
这三个标签可以说是好基友,这一组标签可以帮助我们实现多条件筛选的功能,有点类似于 Java 中 switch。
举例一个简单的例子,现在我们好比有一个学生表,我们可以根据性别进行查询,也可以根据姓名查询,但是,这两个查询只能每次按照一种条件去查。这也就是说,要么是按照性别去查询,要么按照姓名查询,两个不能同时做并集查询。
那么我们如何去做这个条件筛选呢?最好的办法就是使用 choose when otherwise 这一组标签,我们来写例子。
我这里就随便写点条件,我们先传递 age 为 1 的参数。
然后 age 为 2
最后传递一个除了 1 和 2 的数字。
3. where
这个标签是为什么会出现的呢,我们可以直接看官网~~~
是的,没有错,拼接错误,如果想要避免这样的错误,我们可以直接使用 where 标签,MyBatis 会帮我们避免这个问题。
看看效果~
这里因为我们 age 都是 1,所以只能有两种结果~~
4. set
set 其实和 where 标签类似,set 主要用在修改中,看看官网的例子
然后我们自己写一个
这里我和大家说一下,最好可以使用包装类,因为包装类中的 “int” 默认是 null,而不是 0!!!
5. trim
trim 可以说是一个强化器,可以自己进行定义。
先来看看 trim 的属性
prefix:在整个 SQL 前添加添加
suffix:在整个 SQL 后添加
prefixOverrides:去除 SQL 语句前面的关键字或者字符,该关键字或者字符由 prefixOverrides 属性指定,假设该属性指定为 "AND",当sql语句的开头为 "AND",trim标签将会去除该 "AND"
suffixOverrides:去除 SQL 语句后面的关键字或者字符,该关键字或者字符由 suffixOverrides 属性指定
然后我们来看看官网的例子
这里我就不贴图片了,大家自己进行测试。
6. foreach
这个 foreach 还是比较常用的,用于循环,当然,里面属性也比较多
item 表示集合中每一个元素进行迭代时的别名
index 指定一个名字用于表示在迭代过程中,每次迭代到的位置
open 表示该语句以什么开始,好比 MySQL 中 IN 操作,就是以 ( 开始
separator 表示在每次进行迭代之间以什么符号作为分隔符
close 表示以什么结束,这个一般用来和 open 配合着一起使用。
我们这里来举一个例子。
我们修改一下,然后我们传递一个 ages 数组。
是 OK 的~
7. bind
最后这个不是很常用,这是因为很少有人注意这个东西,但是我和大家说啊,这个东西还是可以的,来给大家看看这玩意。
可以看到啊,这个东西很吊的。直接在动态 SQL 中进行拼接,然后进行操作。
说实话,我是一次都没有用过,但是,这让我知道了,我以后肯定会用这个去做。
到这里为止,我们的 MyBatis 动态 SQL 就完成了,东西有点多,大家好好消化一下。
大家可以自己好好查查看,有不懂的可以联系我 QQ:2100363119
欢迎大家访问我的网站:https://www.lemon1234.com
可以的话关注一下我的公众号,就在我网站,每天都有更新~~~,无限资源畅游 Java,感谢~