Mybatis 动态sql(转载)
原文地址:http://www.cnblogs.com/dongying/p/4092662.html
传统的使用JDBC的方法,相信大家在组合复杂的的SQL语句的时候,需要去拼接,稍不注意哪怕少了个空格,都会导致错误。Mybatis的动态SQL功能正是为了解决这种问题,其通过 if, choose, when, otherwise, trim, where, set, foreach标签,可组合成非常灵活的SQL语句,从而提高开发人员的效率。下面就去感受Mybatis动态SQL的魅力吧:
1. if: 你们能判断,我也能判断!
作为程序猿,谁不懂 if ! 在mybatis中也能用 if 啦:
- <select id="findUserById" resultType="user">
- select * from user where
- <if test="id != null">
- id=#{id}
- </if>
- and deleteFlag=0;
- </select>
上面例子:如果传入的id 不为空,那么才会SQL才拼接id = #{id}。这个相信大家看一样就能明白,不多说。
细心的人会发现一个问题:"你这不对啊!要是你传入的id为null, 那么你这最终的SQL语句不就成了 select * from user where and deleteFlag=0, 这语句有问题!"
是啊,这时候,mybatis的 where 标签就该隆重登场啦:
2. where, 有了我,SQL语句拼接条件神马的都是浮云!
咱们通过where改造一下上面的例子:
- <select id="findUserById" resultType="user">
- select * from user
- <where>
- <if test="id != null">
- id=#{id}
- </if>
- and deleteFlag=0;
- </where>
- </select>
有些人就要问了: "你这都是些什么玩意儿!跟上面的相比,不就是多了个where标签嘛!那这个还会不会出现 select * from user where and deleteFlag=0 ?"
的确,从表面上来看,就是多了个where标签而已,不过实质上, mybatis是对它做了处理,当它遇到AND或者OR这些,它知道怎么处理。其实我们可以通过 trim 标签去自定义这种处理规则。
3. trim : 我的地盘,我做主!
上面的where标签,其实用trim 可以表示如下:
- <trim prefix="WHERE" prefixOverrides="AND |OR ">
- ...
- </trim>
它的意思就是:当WHERE后紧随AND或则OR的时候,就去除AND或者OR。除了WHERE以外,其实还有一个比较经典的实现,那就是SET。
4. set: 信我,不出错!
- <update id="updateUser" parameterType="com.dy.entity.User">
- update user set
- <if test="name != null">
- name = #{name},
- </if>
- <if test="password != null">
- password = #{password},
- </if>
- <if test="age != null">
- age = #{age}
- </if>
- <where>
- <if test="id != null">
- id = #{id}
- </if>
- and deleteFlag = 0;
- </where>
- </update>
问题又来了: "如果我只有name不为null, 那么这SQL不就成了 update set name = #{name}, where ........ ? 你那name后面那逗号会导致出错啊!"
是的,这时候,就可以用mybatis为我们提供的set 标签了。下面是通过set标签改造后:
- <update id="updateUser" parameterType="com.dy.entity.User">
- update user
- <set>
- <if test="name != null">name = #{name},</if>
- <if test="password != null">password = #{password},</if>
- <if test="age != null">age = #{age},</if>
- </set>
- <where>
- <if test="id != null">
- id = #{id}
- </if>
- and deleteFlag = 0;
- </where>
- </update>
这个用trim 可表示为:
- <trim prefix="SET" suffixOverrides=",">
- ...
- </trim>
WHERE是使用的 prefixOverrides(前缀), SET是使用的 suffixOverrides (后缀),看明白了吧!
5. foreach: 你有for, 我有foreach, 不要以为就你才屌!
java中有for, 可通过for循环,同样, mybatis中有foreach, 可通过它实现循环,循环的对象当然主要是java容器和数组。
- <select id="selectPostIn" resultType="domain.blog.Post">
- SELECT *
- FROM POST P
- WHERE ID in
- <foreach item="item" index="index" collection="list"
- open="(" separator="," close=")">
- #{item}
- </foreach>
- </select>
将一个 List 实例或者数组作为参数对象传给 MyBatis,当这么做的时候,MyBatis 会自动将它包装在一个 Map 中并以名称为键。List 实例将会以"list"作为键,而数组实例的键将是"array"。同样,当循环的对象为map的时候,index其实就是map的key。
6. choose: 我选择了你,你选择了我!
Java中有switch, mybatis有choose。
- <select id="findActiveBlogLike"
- resultType="Blog">
- SELECT * FROM BLOG WHERE state = 'ACTIVE'
- <choose>
- <when test="title != null">
- AND title like #{title}
- </when>
- <when test="author != null and author.name != null">
- AND author_name like #{author.name}
- </when>
- <otherwise>
- AND featured = 1
- </otherwise>
- </choose>
- </select>
以上例子中:当title和author都不为null的时候,那么选择二选一(前者优先),如果都为null, 那么就选择 otherwise中的,如果tilte和author只有一个不为null, 那么就选择不为null的那个。
纵观mybatis的动态SQL,强大而简单,相信大家简单看一下就能使用了。
Mybatis 动态sql(转载)的更多相关文章
- 深入浅出Mybatis系列(九)---强大的动态SQL(转载)
原文出处:http://www.cnblogs.com/dongying/p/4092662.html 上篇文章<深入浅出Mybatis系列(八)---mapper映射文件配置之select.r ...
- mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...
- 9.mybatis动态SQL标签的用法
mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...
- 自己动手实现mybatis动态sql
发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...
- Mybatis动态SQL单一基础类型参数用if标签
Mybatis动态SQL单一基础类型参数用if标签时,test中应该用 _parameter,如: 1 2 3 4 5 6 <select id="selectByName" ...
- 超全MyBatis动态SQL详解!( 看完SQL爽多了)
MyBatis 令人喜欢的一大特性就是动态 SQL. 在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的. MyBatis 动态 SQL 的出现, 解决了这个麻烦. My ...
- Mybatis动态SQL简单了解 Mybatis简介(四)
动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ } Mybatis应用中,S ...
- mybatis原理分析学习记录,mybatis动态sql学习记录
以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...
- mybatis 动态sql和参数
mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...
随机推荐
- mybatis的xml文件中的CDATA的使用
mybatis的xml文件中的CDATA的使用 <!--查询列表--> <select id="queryListPage" parameterType=&quo ...
- Json序列化日期/Date(xxxx)/ JS转化为常用日期格式
记录开发过程中的代码片段,方便日后归纳.总结,效果如图所示: 转换前: 转换后: 代码如下,需要的朋友们自取: //JS转化为json常用日期格式 function FormatToDate(v ...
- linux 使用timedatectl 修改时区和时间
使用timedatectl可以进行如下常见操作 1.查看当前时间/日期/时区:timedatectl或者timedatectl status 2.查看所有可用时区:timedatectl list-t ...
- PEP8-python编码规范(下)
1.结尾逗号 结尾的逗号通常是可选的,除了在构成一个元素的元组时是强制性需要的(在Python 2 中,它们对 print 语句有语义).为了清晰起见,建议将后者用括号括起来(在技术上是多余的). Y ...
- 《Python编程从0到1》笔记1——表达式的风格(前缀、中缀、后缀)
运算符和运算数组成表达式.运算符和运算数的出现次序会影响表达式乃至程序设计语言的风格. 1.前缀表达式 前缀,是指运算符的位置在前.前缀风格的一个例子是函数调用,如求最大值函数:max(3, 2, 5 ...
- 应用安全 - 社工 - By 大数据 - shodan - 汇总
使用 | 命令 搜索语法 hostname: 搜索指定的主机或域名,例如 hostname:”google” port: 搜索指定的端口或服务,例如 port:”” country: 搜索指定的国家, ...
- 【机器学习】【数字信号处理】矢量量化(Vector Quantization)
http://blog.csdn.net/zouxy09 这学期有<语音信号处理>这门课,快考试了,所以也要了解了解相关的知识点.呵呵,平时没怎么听课,现在只能抱佛脚了.顺便也总结总结,好 ...
- Layer 弹出层抖动问题
layer.open({ type: 2, anim: 5,//加上anim,渐显 title: '品牌列表', shadeClose: fal ...
- LayaAir疑难杂症之四:laya引擎自动断点到bundle.js文件中且无报错,但程序不再执行
在一次断点调试中,突然程序不再按照博主指定的断点执行,莫名其妙端点到了bundle.js文件中的某一行中,这是不应该的,第一次时间反应就是引擎出了问题,但是总不能让博主卸载重装吧. 经过查找资料,询问 ...
- SPOJ 703 SERVICE - Mobile Service 题解
题面 好题啊!~ 设f[i][j][k][l]表示已经处理完前i个请求后,a在j,b在k,c在l的最小值是多少: 那么f[i][p[i]][k][l]=min(f[i][p[i]][k][l],f[i ...