mybatis动态SQL语句
一 if标签
1
2
3
4
5
6
|
<select id= " getStudentListLikeName " parameterType= "StudentEntity" resultMap= "studentResultMap" > SELECT * from STUDENT_TBL ST < if test= "studentName!=null and studentName!='' " > WHERE ST.STUDENT_NAME LIKE CONCAT(CONCAT( '%' , #{studentName}), '%' ) </ if > </select> |
二 where标签
1
2
3
4
5
6
7
8
9
10
11
|
<select id= "getStudentListWhere" parameterType= "StudentEntity" resultMap= "studentResultMap" > SELECT * from STUDENT_TBL ST <where> < if test= "studentName!=null and studentName!='' " > ST.STUDENT_NAME LIKE CONCAT(CONCAT( '%' , #{studentName}), '%' ) </ if > < if test= "studentSex!= null and studentSex!= '' " > AND ST.STUDENT_SEX = #{studentSex} </ if > </where> </select> |
如果它包含的标签中有返回值的话就插入一个where。此外如果标签返回的内容是以AND或OR开头的,则它会剔除掉。
三 set 标签
使用set+if标签修改后,如果某项为null则不进行更新,而是保持数据库原值
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<update id= "updateStudent" parameterType= "StudentEntity" > UPDATE STUDENT_TBL <set> < if test= "studentName!=null and studentName!='' " > STUDENT_TBL.STUDENT_NAME = #{studentName}, </ if > < if test= "studentSex!=null and studentSex!='' " > STUDENT_TBL.STUDENT_SEX = #{studentSex}, </ if > < if test= "studentBirthday!=null " > STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday}, </ if > < if test= "classEntity!=null and classEntity.classID!=null and classEntity.classID!='' " > STUDENT_TBL.CLASS_ID = #{classEntity.classID} </ if > </set> WHERE STUDENT_TBL.STUDENT_ID = #{studentID}; </update> |
四 trim标签
trim是更灵活的去处多余关键字的标签,他可以实践where和set的效果,where例子的等效trim语句
1
2
3
4
5
6
7
8
9
10
11
|
<select id= "getStudentListWhere" parameterType= "StudentEntity" resultMap= "studentResultMap" > SELECT * from STUDENT_TBL ST <trim prefix= "WHERE" prefixOverrides= "AND|OR" > < if test= "studentName!=null and studentName!='' " > ST.STUDENT_NAME LIKE CONCAT(CONCAT( '%' , #{studentName}), '%' ) </ if > < if test= "studentSex!= null and studentSex!= '' " > AND ST.STUDENT_SEX = #{studentSex} </ if > </trim> </select> |
set例子的等效trim语句
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<update id= "updateStudent" parameterType= "StudentEntity" > UPDATE STUDENT_TBL <trim prefix= "SET" suffixOverrides= "," > < if test= "studentName!=null and studentName!='' " > STUDENT_TBL.STUDENT_NAME = #{studentName}, </ if > < if test= "studentSex!=null and studentSex!='' " > STUDENT_TBL.STUDENT_SEX = #{studentSex}, </ if > < if test= "studentBirthday!=null " > STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday}, </ if > < if test= "classEntity!=null and classEntity.classID!=null and classEntity.classID!='' " > STUDENT_TBL.CLASS_ID = #{classEntity.classID} </ if > </trim> WHERE STUDENT_TBL.STUDENT_ID = #{studentID}; </update> |
五 choose (when, otherwise)
有时候并不想应用所有的条件,而只是想从多个选项中选择一个。MyBatis提供了choose 元素,按顺序判断when中的条件出否成立,如果有一个成立,则choose结束。当choose中所有when的条件都不满则时,则执行 otherwise中的sql。类似于Java 的switch语句,choose为switch,when为case,otherwise则为default。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<select id= "getStudentListChooseEntity" parameterType= "StudentEntity" resultMap= "studentResultMap" > SELECT * from STUDENT_TBL ST <where> <choose> <when test= "studentName!=null and studentName!='' " > ST.STUDENT_NAME LIKE CONCAT(CONCAT( '%' , #{studentName}), '%' ) </when> <when test= "studentSex!= null and studentSex!= '' " > AND ST.STUDENT_SEX = #{studentSex} </when> <when test= "studentBirthday!=null" > AND ST.STUDENT_BIRTHDAY = #{studentBirthday} </when> <when test= "classEntity!=null and classEntity.classID !=null and classEntity.classID!='' " > AND ST.CLASS_ID = #{classEntity.classID} </when> <otherwise></otherwise> </choose> </where> </select> |
六 foreach
对于动态SQL 非常必须的,主是要迭代一个集合,通常是用于IN 条件。List实例将使用“list”做为键,数组实例以“array”做为键。
1 参数为list实例的写法
SqlMapper.xml
1
2
3
4
5
6
7
|
<select id= "getStudentListByClassIDs" resultMap= "studentResultMap" > SELECT * FROM STUDENT_TBL ST WHERE ST.CLASS_ID IN <foreach collection= "list" item= "classList" open= "(" separator= "," close= ")" > #{classList} </foreach> </select> |
Java
1
2
3
4
5
6
7
|
List<String> classList = new ArrayList<String>(); classList.add( "20000002" ); classList.add( "20000003" ); List<StudentEntity> studentList = studentMapper.getStudentListByClassIDs(classList); for (StudentEntity entityTemp : studentList){ System.out.println(entityTemp.toString()); } |
2 参数为Array实例的写法
SqlMapper.xml
1
2
3
4
5
6
7
|
<select id= "getStudentListByClassIDs" resultMap= "studentResultMap" > SELECT * FROM STUDENT_TBL ST WHERE ST.CLASS_ID IN <foreach collection= "array" item= "ids" open= "(" separator= "," close= ")" > #{ids} </foreach> </select> |
Java
1
2
3
4
5
6
7
|
String[] ids = new String[ 2 ]; ids[ 0 ] = "20000002" ; ids[ 1 ] = "20000003" ; List<StudentEntity> studentList = studentMapper.getStudentListByClassIDs(ids); for (StudentEntity entityTemp : studentList){ System.out.println(entityTemp.toString()); } |
mybatis动态SQL语句的更多相关文章
- mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...
- Mybatis 动态Sql语句《常用》
MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉 ...
- mybatis 动态sql语句(3)
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. ...
- mybatis 动态sql语句(1)
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. ...
- 【转】mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
转自:除非申明,文章均为一号门原创,转载请注明本文地址,谢谢! 转载地址:http://blog.csdn.net/kutejava/article/details/9164353#t5 1. if ...
- 7. mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
转自:http://www.kyjszj.com/htzq/79.html 1. if 语句 (简单的条件判断) 2. choose (when,otherwize) ,相当于java 语言中的 sw ...
- MyBatis学习总结(11)——MyBatis动态Sql语句
MyBatis中对数据库的操作,有时要带一些条件,因此动态SQL语句非常有必要,下面就主要来讲讲几个常用的动态SQL语句的语法 MyBatis中用于实现动态SQL的元素主要有: if choose(w ...
- mybatis动态sql语句学习(一)
动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格 ...
- mybatis 动态sql语句(2)
什么是动态SQL MyBatis的一个强大特性之一通常是它的动态SQL能力.如果你有使用JDBC或其他相似框架的经验,你就明白条件串联SQL字符串在一起是多么地痛苦,确保不能忘了空格或者在列表的最后的 ...
随机推荐
- 【hibernate 执行方法未插入数据库】hibernate的save方法成功执行,但是未插入到数据库
今天做项目,碰上这个问题: hibernate的save方法成功执行,但是未插入到数据库. Dao层代码: @Override public void save(T t) { this.getSess ...
- 【转】Linux 查看内存(free buffer cache)
转自:http://elf8848.iteye.com/blog/1995638 Linux下如何查内存信息,如内存总量.已使用量.可使用量.经常使用Windows操作系统的朋友,已经习惯了如果空闲的 ...
- 性能测试-ORACLE性能监控
通过lr做性能测试的过程,通过监控Oracle数据库的性能 采用的监控工具:PeOny PeOny安装 1. 安装服务端 1) LINUX平台安装 解压缩peony3.x.0.x.tar.gz文件,b ...
- CentOS安装PHP和mysql
新生在不会编译的情况下: 1.安装PHP5 yum install php 根据提示输入Y直到安装完成 2.安装PHP组件,使 PHP5 支持 MySQL yum install php-mysql ...
- 【hdu3948-不同回文串的个数】后缀数组
题意:求不同回文串的个数 n<=10^5 题解: 先按照manacher的构造方法改造一遍串,然后跑一遍manacher. 如ababa--> $#a#b#a#b#a#@ 然后跑一遍后缀数 ...
- Eclipse 的 Debug 介绍与技巧【转载】
没有任何程序员能够一气呵成的写出没有任何 Bug 的代码,所以很多程序员有相当一部分时间是花费在 Debug 上的,程序调试是每个程序员必须面对的工作.如何使用 Eclipse 进行有效的.尤其是高效 ...
- c#静态构造函数
作用是初始化一些类的静态成员 1.在实例化类的对象,或者引用任何的静态成员之前,.Net自动调用此构造函数,而且只调用一次 2.没有任何修饰符,也没有参数 3.一个类只能有一个静态构造函数 4.无参的 ...
- WPF拖放功能实现zz
写在前面:本文为即兴而作,因此难免有疏漏和词不达意的地方.在这里,非常期望您提供评论,分享您的想法和建议. 这是一篇介绍如何在WPF中实现拖放功能的短文. 首先要读者清楚的一件事情是:拖放主要分为拖放 ...
- BZOJ2758 : [SCOI2012]Blinker的噩梦
首先将包含关系建树. 方法是将每个图形拆成上半边和下半边,从左往右扫描线,用Splay从下到上维护扫描线上所有图形. 每次加入一个新的图形$x$的时候,看看它下方第一个图形$y$,如果$y$是上半边, ...
- [R语言]foreach和doParallel包实现多个数据库同时查询
R语言在进行数据库查询时,每执行一条语句,都会阻塞.直到查询语句返回结果之后,才会进行下一条语句. 为了能够实现同时对多个数据库进行查询,以节省顺序执行下来的时间,首先考虑通过多线程来进行数据库查询. ...