mybatis4动态SQL

动态SQL等

动态SQL是Mybatis的一个强大特性,在使用JDBC操作数据时,如果查询条件特别多,将条件串联成SQL字符串是一件痛苦的事情,通常的解决方法是写很多的if-else条件语句对字符串进行拼接.并确保不能忘了空格或在字段的最后省略逗号.Mybatis使用一种强大的的动态Sql语言来改善这种情形.动态SQL基于OGNL的表达式,可使我们方便的在SQL语句中实现某些逻辑,用于实现动态SQL的元素如下:

实现动态SQL的元素(9个标签)

 if:利用if实现简单的条件选择

 choose(when,otherwise):相当于Java的switch语句,通常与when和otherwise搭配.

 where:简化SQL语句中where的条件判断

 set:解决动态更新语句

 trim:可以灵活的去除多余的关键字

 foreach:迭代一个集合,通常用于in条件

 bind:可以使用OGNL表达式创建一个变量并将其绑定到上下文中

三. 使用if+where实现多条件查询

 if:利用if实现简单的条件选择(条件判断)

 where:where元素标签会自动识别其标签内是否有返回值,若有,就插入一个where.此外,若该标签返回的内容是以and或者or开头,会自动剔除.

四. if+trim实现多条件查询

1. 分析

在Mybatis中除了if+where实现多条件查询,还有一个更为灵活的元素trim可以替代之前的做法.

2. trim元素

trim元素也会自动识别标签内是否有返回值,若有返回值,会在自己包含的内容前加上某些前缀,可以在其后加上某些后缀,与之对应的属性是prifix和suffix,也可以把包含内容的首部某些内容覆盖(忽略),或者把尾部的某些内容覆盖,与之对应的属性是prefixOverrides和suffixOverrides

五. if+set改造更新操作

六. Mybatis入参为List类型的foreach迭代

七. choose(when,otherwise)

有时候我们并不想应用所有的条件,而只是想从多个选项中选择一个。而使用if标签时,只要test中的表达式为 true,就会执行 if 标签中的条件。MyBatis 提供了 choose 元素。if标签是与(and)的关系,而 choose 是或(or)的关系。

choose标签是按顺序判断其内部when标签中的test条件出否成立,如果有一个成立,则 choose 结束。当 choose 中所有 when 的条件都不满则时,则执行 otherwise 中的sql。类似于Java 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。

八. bind标签

bind标签可以使用OGNL表达式创建一个变量并将其绑定到上下文中

使用concat()函数连接字符串,在MySql中,这个函数支持多个参数,但是在Oracle中支持两个参数.由于不同数据库之间的语法差异,如果更换数据库,有些SQL语句可能就需要重写.针对这种情况,可以使用bind标签来避免由于更换数据库带来的一些麻烦

九. sql标签+include标签(不属于动态SQL)

Mybatis中的sql标签是为了避免在项目开发过程中重复编写大量相同的sql语句

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值