MyBatis基于XML的使用——动态sql

1、动态sql
动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它
类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。
利用动态 SQL,可以彻底摆脱这种痛苦。
使用动态 SQL 并非一件易事,但借助可用于任何 SQL 映射语句中的
强大的动态 SQL 语言,MyBatis 显著地提升了这一特性的易用性。
如果你之前用过 JSTL 或任何基于类 XML 语言的文本处理器,你对动
态 SQL 元素可能会感觉似曾相识。在 MyBatis 之前的版本中,需要花时间了解大量的元素。借助功能强大的基于 OGNL 的表达式,MyBatis 3 替换了之前的大部分元素,大大精简了元素种类,现在要学习的元素种类比原来的一半还要少。
if
choose (when, otherwise)
trim (where, set)
foreach
bind
sql片段

1、if
EmpDao.xml
在这里插入图片描述
Empdao
在这里插入图片描述
test:
在这里插入图片描述
在这里插入图片描述
EmpDTO
在这里插入图片描述
在这里插入图片描述
看起来测试是比较正常的,但是大家需要注意的是如果我们传入的参
数值有缺失会怎么呢?这个时候拼接的sql语句就会变得有问题,例如不传参数或者丢失最后一个参数,那么语句中就会多一个where或者and的关键字,因此
在mybatis中也给出了具体的解决方案:
where
where 元素只会在子元素返回任何内容的情况下才插入 “WHERE” 子
句。而且,若子句的开头为 “AND” 或 “OR”,where 元素也会将它们去除。

empmapper.xml
在这里插入图片描述
其他的不需要做修改
现在看起来没有什么问题了,但是我们的条件添加到了拼接sql语句的
前后,那么我们该如何处理呢?
使用trim
trim截取字符串:
prefix:前缀,为sql整体添加一个前缀
prefixOverrides:去除整体字符串前面多余的字符
suffixOverrides:去除后面多余的字符串
在这里插入图片描述
3、foreach
动态 SQL 的另一个常见使用场景是对集合进行遍历(尤其是在构建
IN 条件语句的时候)
empmapper.xml
在这里插入图片描述
在这里插入图片描述
4、choose、when、otherwise
有时候,我们不想使用所有的条件,而只是想从多个条件中选择一个
使用。针对这种情况,MyBatis 提供了 choose 元素,它有点像 Java 中的
switch 语句
empmapper.xml
在这里插入图片描述
5、set
用于动态更新语句的类似解决方案叫做 set。set 元素可以用于动态包
含需要更新的列,忽略其它不更新的列。

empmapper.xml

在这里插入图片描述
当然使用set修改数据也可以使用trim来修改(效果一致):例如
在这里插入图片描述
达到的效果是一样的,但是个人建议使用set更好一点,不需要写那么多代码
bind元素和sql片段
bind 元素允许你在 OGNL 表达式以外创建一个变量,并将其绑定到当前的上下文。
sql这个元素可以用来定义可重用的 SQL 代码片段,以便在其它语句中使用。 参数可以静态地在加载的时候)确定下来,并且可以在不同的 include 元素中定义不同的参数值。
在这里插入图片描述
在这里插入图片描述
MyBatis常用OGNL表达式
在这里插入图片描述
使用foreach实现循环逐条插入:
empmapper.xml
在这里插入图片描述
empdao
在这里插入图片描述

emp.pojo
在这里插入图片描述
在这里插入图片描述
test
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值