myBatis xml文件SQL编写( if、where、if-else、set 、foreach )
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了myBatis xml文件SQL编写( if、where、if-else、set 、foreach ),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3469字,纯文字阅读大概需要5分钟。
内容图文
![myBatis xml文件SQL编写( if、where、if-else、set 、foreach )](/upload/InfoBanner/zyjiaocheng/863/035af7a6cdc147a6bf46c1b07fa4e55e.jpg)
myBatis xml文件SQL编写( if、where、if-else、set 、foreach )
MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其它类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句的痛苦。例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL 这一特性可以彻底摆脱这种痛苦。
虽然在以前使用动态 SQL 并非一件易事,但正是 MyBatis 提供了可以被用在任意 SQL 映射语句中的强大的动态 SQL 语言得以改进这种情形。
动态 SQL 元素和 JSTL 或基于类似 XML 的文本处理器相似。在 MyBatis 之前的版本中,有很多元素需要花时间了解。MyBatis 3 大大精简了元素种类,现在只需学习原来一半的元素便可。MyBatis 采用功能强大的基于 OGNL 的表达式来淘汰其它大部分元素。
1. if 标签
mapper中编写AQL,使用<if test = ' '> </if>
标签,可以使你的接口很便捷。
代码如下(示例):
<select id="getStudentByName" parameterType="java.util.Map" resultType="java.util.Map">
select * from student
<if test = " record.name != null ">
where name =#{record.name}
</if>
</select>
<select id="getStudentByIdOrName" parameterType="java.util.Map" resultType="java.util.Map">
select * from student
where
<if test = " record.id != null ">
id = #{record.id}
</if>
<if test = " record.name != null and record.name != '' ">
and name = #{record.name}
</if>
</select>
如上面的代码,如果当你的id为空时,name前面的and是没有必要的,运行会抛异常
或者当这两个都为空时,只剩一个空的where,还是会报错,这个时候就需要<where>
标签了。
2. where 标签
<where>
标签 只会在至少有一个子元素的条件返回 SQL 子句的情况下才去插入WHERE子句。而且,若语句的开头为AND或OR,<where>
标签也会将它们去除。
使用<where>
标签,代码将会变得很优美。
代码如下(示例):
<select id="getStudentByIdOrName" parameterType="java.util.Map" resultType="java.util.Map">
select * from student
<where>
<if test = " record.id != null ">
and id = #{record.id}
</if>
<if test = " record.name != null and record.name != '' ">
and name = #{record.name}
</if>
</where>
</select>
3. choose, when, otherwise 标签 (if - else if - else )
在myBatis中是不支持 if - else 的,想要是用 if - else 的话,可以使用<choose>
标签代替。
<choose>
标签 、<when>
标签、<otherwise>
标签 ,<otherwise>
有点像 Java 中的switch语句。
代码如下(示例):
<select id="getStudentByKeyword" parameterType="java.util.Map" resultType="java.util.Map">
SELECT * FROM student
WHERE state = '已入学'
<choose>
<when test="record.name != null and record.name != ''">
AND name like #{record.name}
</when>
<when test="record.remark != null and record.remark != ''">
AND remark like #{record.remark }
</when>
<otherwise>
AND status = 1
</otherwise>
</choose>
</select>
4. set 标签
代码如下(示例):
<update id="updateStudentBySet" parameterType="java.util.Map" resultType="java.util.Map">
update student
<set>
<if test="record.name != null and record.name != ''">
name = #{record.name},
</if>
<if test="record.sex != null and record.sex != ''">
sex = #{record.sex },
</if>
</set>
where id = #{record.id}
</update>
<set>
标签会在成功拼接的条件前加上SET单词且最后一个”,”号会被无视掉,但是有可能需要”,”的地方不能省略”,”否则异常。
5. foreach 标签
foreach标签用于遍历生成单个或多个数据。
代码如下(示例):
<select id="getStudentCount" parameterType="java.util.Map" resultType="java.util.Map">
select COUNT(*) count from student
<where>
<if test="record.ids != null">
and id in
<foreach item="item" index="index" collection="record.ids " open="(" separator="," close=")">
#{item}
</foreach>
</if>
</where>
</select>
提示:关于mybatis的动态sql,建议查看,官方文档
内容总结
以上是互联网集市为您收集整理的myBatis xml文件SQL编写( if、where、if-else、set 、foreach )全部内容,希望文章能够帮你解决myBatis xml文件SQL编写( if、where、if-else、set 、foreach )所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。