深入浅出 最新版 MyBatis-3.5.6_ 6. MyBatis 动态 SQL

一、什么是动态 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,感谢~

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

他 他 = new 他()

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值