MyBatis:学习笔记(4)——动态SQL
MyBatis:学习笔记(4)——动态SQL
如果使用JDBC或者其他框架,很多时候需要你根据需求手动拼装SQL语句,这是一件非常麻烦的事情。MyBatis提供了对SQL语句动态的组装能力,而且他只有几个基本的元素,十分简单明了,即大量的判断都可以在MyBatis的映射XML文件里面配置,已达到我们需要大量代码才可以实现的功能。
动态SQL元素
IF元素
IF元素是我们最常用的判断语句,相当于Java中的IF语句。它常常与test属性联合使用。
<select id="findOffice" parameterType="String" resultType="com.mrsaber.model.office">
SELECT * FROM ms_office WHERE 1=1
<if test="ofName != null and ofName!=''">
and of_name = #{ofName}
</if>
</select>
这句话的意思是说,我们把参数ofName传递进入到映射器中,采取构造对ofName的查询。如果这个参数为空,就返回所有的office!通过MyBatis的条件语句我们可以节省许多拼接SQL的工作,把精力集中在XML的维护上。
CHOOSE、WHEN、OTHERWISE元素
IF元素是一种非此即彼的关系,很多时候我们所面的不是一张非此即彼的选择,会有第三种或者更多的选择,也即是说,我们需要类似于SWITCH...CASE....DEFAULT语句,而在映射器中CHOOSE、WHEN、OTHERWISE承担了这个功能。
<select id="findOffice" parameterType="com.mrsaber.model.office" resultType="com.mrsaber.model.office">
SELECT * FROM ms_office
WHERE 1=1
<choose>
<when test="ofName != null and ofName!=''">
AND of_name = #{ofName}
</when>
<when test="ofNo != null and ofNo!=''">
AND of_no = #{ofNo}
</when>
<otherwise>
AND of_addr IS NOT NULL
</otherwise>
</choose>
</select>
这样MyBatis就会根据参数的设置进行判断来动态组装SQL,以满足不同业务的要求。远比Hibernate和JDBC进行大量判断Java代码要清晰和明确的多。
TRIM、WHERE、SET元素
WHERE
上面两组语句我们加入了一个条件“1=1”,如果没有加入这个条件就会变成一个错误语句,即WHERE AND.....
即WHERE后面直接跟上了拼装语句的AND,是不合法的。
但是我们可以用WHERE元素去处理SQL已达到不写该条件的效果。
<select id="findOffice1" parameterType="String" resultType="com.mrsaber.model.office">
SELECT * FROM ms_office
<where>
<if test="ofName != null and ofName!=''">
and of_name = #{ofName}
</if>
</where>
</select>
现在,我们不用再语句中写WHERE 1=1 了,而是加入WHERE元素,系统会自动判断如果条件成立,才会加入WHERE这个SQL关键字到组装的SQL里面,否则不加入。
TRIM
有时我们需要去掉一些特殊的SQL语法,比如常见的and、or。而使用trim元素可以达到我们预期的效果。
<select id="findOffice2" parameterType="String" resultType="com.mrsaber.model.office">
SELECT * FROM ms_office
<trim prefix="WHERE" prefixOverrides="AND">
<if test="ofName != null and ofName!=''">
AND of_name = #{ofName}
</if>
</trim>
</select>
tirm元素意味着我们要去掉一些特殊的字符串,prefix代表的是语句的前缀,而prefixOverrides代表的是你需要去掉的那种字符串,上面写法与WHERE是等效的。
SET
我们需要更新一个对象时,如果我们发送所有的属性去更新一遍,对网络带宽消耗较大,性能最佳的办法是把主键和更新字段的值传递给SQL更新即可。例如office表中有一个主键和两个字段,如果一个个去更新需要写2条SQL,如果有1000个字段呢?显示是不方便的。在MyBatis中,我们常常可以使用set元素来完成这些功能。
也即是说我们如果只更新一个对象的某几个字段时,可以使用SET元素来实现。
<update id="findOffice2" parameterType="com.mrsaber.model.office" >
UPDATE ms_office
<set>
<if test="ofName != null and ofName!=''">
of_name = #{ofName}
</if>
<if test="ofAddr != null and ofAddr!=''">
of_addr = #{ofAddr}
</if>
</set>
where of_No = #{ofNo}
</update>
FOREACH
显然foreach是一个循环语句,它的作用时遍历集合,它能够很好的支持数组、List、Set接口的集合,对此提供遍历的功能。
在数据库中,数据字典是经常使用的内容,比如在用户表中,性别可以分为男、女或者未知,我们把性别作为一个字典,定义如下:
1——男,2——女,0——未知
实际工作中,用户可能查找非未知性别的用户,也可能查找性和未知性别的用户,或者男性和未知性别的用户等,具体的参数需要使用foreach元素去确定。
<select id="findUser" resultType="com.mrsaber.model.user">
SELECT * FROM ms_user WHERE user_sex IN
<foreach collection="sexList" item="sex" index="index" open="(" separator="," close=")">
#{sex}
</foreach>
</select>
说明:
collection配置的sexList是传递进来的参数名称,支持数组、List、Set接口的集合。
item配置的是循环中当前的元素。
index配置的是当期那元素在集合的位置下标。
open和close配置的是以什么符号将这些集合元素包起来。
separator是各个元素的间隔符。
MyBatis:学习笔记(4)——动态SQL的更多相关文章
- MyBatis:学习笔记(4)——动态SQL
MyBatis:学习笔记(4)——动态SQL
- Mybatis学习笔记(六) —— 动态sql
通过mybatis提供的各种标签方法实现动态拼接sql. 需求:根据性别和名字查询用户 查询sql: SELECT id, username, birthday, sex, address FROM ...
- Mybatis学习笔记之---动态sql中标签的使用
动态Sql语句中标签的使用 (一)常用标签 1.<if> if标签通常用于WHERE语句中,通过判断参数值来决定是否使用某个查询条件, 他也经常用于UPDATE语句中判断是否更新某一个字段 ...
- 1.3(Mybatis学习笔记)动态SQL
一.<if> 使用<if>可以根据具体情况来拼接SQL语句,使其更加灵活更加适应我们的需求. <if>的标签体中是需要拼接的语句,满足条件才会将其进行拼接. < ...
- Mybatis学习笔记14 - 动态sql之foreach标签
一.查询给定集合中员工id对应的所有员工信息 示例代码: 接口定义: package com.mybatis.dao; import com.mybatis.bean.Employee; import ...
- Mybatis学习笔记10 - 动态sql之if判断
示例代码: 接口定义: package com.mybatis.dao; import com.mybatis.bean.Employee; import java.util.List; public ...
- Mybatis学习笔记13 - 动态sql之set标签
示例代码: 接口定义: package com.mybatis.dao; import com.mybatis.bean.Employee; public interface EmployeeMapp ...
- Mybatis学习笔记12 - 动态sql之choose(when otherwise)标签
choose (when, otherwise):分支选择:带了break的swtich-case 示例代码: 接口定义: package com.mybatis.dao; import com.my ...
- Mybatis学习笔记11 - 动态sql之trim标签
trim标签体中是整个字符串拼串后的结果.prefix="" 前缀: prefix给拼串后的整个字符串加一个前缀prefixOverrides="" 前缀覆盖: ...
随机推荐
- STL学习笔记(迭代器类型)
迭代器类型 迭代器是一种“能够遍历某个序列内的所有元素”的对象.它可以透过与一般指针一致的接口来完成自己的工作. 不同的迭代器具有不同的”能力“(行进和存取能力) Input迭代器 Input迭代器只 ...
- asp.net中UpdatePanel数据加载成功后回调
//添加UpdatePanel加载成功后执行的js方法 Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(onPageLoade ...
- java jdk 环境变量设置
我的电脑点右键,选择“属性”,选择“高级”标签,进入环境变量设置,分别设置如下三个环境变量: 设置JAVA_HOME: 一是为了方便引用,比如,JDK安装在C:\jdk1.6.0目录里,则设置JAVA ...
- 网页抓取工具Teleport Ultra简介及如何使用
Teleport Ultra是一款专业的离线浏览器,能够快速.准确地从网络抓取数据并保存到本地,实现离线浏览的目的.它可以从Internet的任何地方抓回你想要的任何文件,它可以在你指定的时间自动登录 ...
- bios文字解释
很多笔记本电脑用户由于不熟悉bios,导致在需要设置bios时不知如何下手,其实bios基本大同小异,熟悉了以后再遇到bios设置就手到擒来了. 今天我们以笔记本电脑为例,进行bios界面的解读. 1 ...
- mysql设置主从同步
1.主从同步定义 主从同步使得数据可以从一个数据库服务器复制到其他服务器上,在复制数据时,一个服务器充当主服务器(master),其余的服务器充当从服务器(slave).因为复制是异步进行的,所以从服 ...
- Mongodb 的学习
传送门: # 官方网站 及 下载地址 https://www.mongodb.com/download-center/enterprise/releases # 之前简单学习的笔记http://www ...
- php序列化&反序列化坑
一: 在php中如果我们统一编码是没有什么问题了,但是很多朋友会发现一个问题就是utf8和gbk编码中返回的值会有所区别: php 在utf8和gbk编码下使用serialize和unserializ ...
- IIS8应用池重启脚本
重启 IIS8 应用程序池的批处理 批处理很简单:c:\windows\system32\inetsrv\AppCmd.exe stop apppool /apppool.name:"ASP ...
- 不同手机根据坐标计算控件、图片的像素,px 与 dp, sp换算公式?
参考该帖子:http://www.cnblogs.com/bluestorm/p/3640786.html PPI = Pixels per inch,每英寸上的像素数,即 "像素密度&qu ...