MyBatis的强大特性之一便是它的动态SQL,以前拼接的时候需要注意的空格、列表最后的逗号等,现在都可以不用手动处理了,MyBatis采用功能强大的基于OGNL的表达式来实现,下面主要介绍下。
一、if标签
if是最常用标签,经常用在判断语句上,可以实现某些简单的条件选择。基本使用示例如下:
<selectid="queryAllUsersByName"resultType="com.example.springboot.mybatisxml.entity.User"> select*fromuserwhere1=1 <iftest="name!=nullandname!=''"> andname=#{name} </if> <iftest="age!=null"> andage=#{age} </if> </select>
二、where标签
上面的例子中使用了“1=1”,是为了避免后续条件不满足时候报错,那有没有办法避免这种写法呢?
当然有,就是接下来要说的where,where标签会自动判断如果包含的标签中有返回值的话,就在sql中插入一个where,如果where标签最后返回的内容是以and 或者or开头的,也会被自动移除掉,上面例子中换成where标签后写法如下:
<selectid="queryAllUsersByName"resultType="com.example.springboot.mybatisxml.entity.User"> select*fromuser <where> <iftest="name!=nullandname!=''"> andname=#{name} </if> <iftest="age!=null"> andage=#{age} </if> </where> </select>
三、trim标签
trim的作用是去除特殊的字符串,它的prefix属性代表语句的前缀,prefixOverrides属性代表需要去除的哪些特殊字符串,prefixOverrides属性会忽略通过管道分隔的字符,后缀的处理和前缀一样。
trim标签的主要属性如下
- prefix:前缀覆盖并增加其内容。
- suffix:后缀覆盖并增加其内容。
- prefixOverrides:前缀判断的条件。
- suffixOverrides:后缀判断的条件。
举两个例子。
使用前缀属性
<selectid="queryAllUsersByName"resultType="com.example.springboot.mybatisxml.entity.User"> select*fromuser <trimprefix="WHERE"prefixOverrides="AND|OR"> <iftest="name!=nullandname!=''"> andname=#{name} </if> <iftest="sex!=null"> orsex=#{sex} </if> <iftest="age!=null"> andage=#{age} </if> </trim> </select>
使用后缀属性
<updateid="update"parameterType="Object"> UPDATEuser <trimprefix="SET"prefixOverrides=","> <iftest="id!=null">,id=#{id}</if> <iftest="name!=null">,name=#{name}</if> <iftest="age!=null">,age=#{age}</if> </trim> WHEREID=#{id} </update>
四、foreach标签
foreach的作用是遍历集合,它能够很好地支持数组和List、Set接口的集合的遍历,往往和sql中的in组合比较多。
foreach标签的主要属性如下
- item:表示循环中当前的元素。
- index:表示当前元素在集合的位置下标。
- collection:配置list的属性名等。
- open和close:配置的是以什么符号将这些集合元素包装起来。
- separator:配置的是各个元素的间隔符。
举个例子:
<selectid="queryAllUsersByName"resultType="com.example.springboot.mybatisxml.entity.User"> select*fromuserwhereidin <foreachitem="id"index="index"collection="userList" open="("separator=","close=")"> #{id} </foreach> </select>
相关文章
标签:数据库运维