mybatis.5.动态SQL
1.动态SQL,解决关联sql字符串的问题,mybatis的动态sql基于OGNL表达式
if语句,在DeptMapper.xml增加如下语句;
<select id="selectByLikeName" resultType="org.mybatis.example.dao.Dept"
parameterType="org.mybatis.example.dao.Dept">
select d.deptno,d.dname,d.loc from dept d where 1=1
<if test="dname!=null and dname!=''">
AND dname like #{dname}
</if>
</select>
DeptMapper.java接口中增加如下代码
public Dept selectByLikeName(Dept dept);
测试类如下:
public class Test23 {
public static void main(String[] args) {
SqlSession session=SqlSessionFactoryUtil.getSqlSession();
DeptMapper mapper=session.getMapper(DeptMapper.class);
Dept d=new Dept();
d.setDname("开发部");
Dept dept=mapper.selectByLikeName(d);
System.out.println(dept.getDname());
}
}
如果查询雇员的姓名,查询出雇员并且找到一些部门呢?
EmpMapper.xml增加如下代码
<select id="selectByLike" resultMap="getEmpresultMap"
parameterType="org.mybatis.example.dao.Emp">
select d.deptno,d.dname,d.loc,e.empno,e.ename
from Dept d join emp e on d.deptno=e.deptno where 1=1
<if test="ename!=null and ename!=''">
AND ename like #{ename}
</if>
<if test="dept!=null and dept.dname!=null">
AND dname like #{dept.dname}
</if>
</select>
EmpMapper.java增加如下代码:
public List<Emp> selectByLike(Emp e);
测试类:
public class Test24 {
public static void main(String[] args) {
SqlSession session=SqlSessionFactoryUtil.getSqlSession();
EmpMapper mapper=session.getMapper(EmpMapper.class);
Emp e=new Emp();
e.setEname("张%");
List<Emp>empList=mapper.selectByLike(e);
for(Emp emp:empList){
System.out.println("所有名字首字母为张的员工是:"+emp.getEname());
}
}
}
3 choose when otherwise语句
有时候针对,有多重选择的情况,可以使用choose语句
<select id="selectByLikeTwo" parameterType="org.mybatis.example.dao.Emp"
resultMap="getEmpresultMap">
select d.deptno,d.dname,d.loc,e.empno,e.ename,e.sal
from Dept d join emp e on d.deptno=e.deptno where 1=1
<choose>
<when test="ename!=null">AND ename like #{ename}</when>
<when test="dept!=null and dept.dname!=null">AND dname=#{dept.dname}</when>
<otherwise>AND sal >5000</otherwise>
</choose>
</select>
EmpMapper.java增加接口
public List<Emp> selectByLikeTwo(Emp e);
public class Test25 {
public static void main(String[] args) {
SqlSession session=SqlSessionFactoryUtil.getSqlSession();
EmpMapper mapper=session.getMapper(EmpMapper.class);
Emp e=new Emp();
Dept d=new Dept();
d.setDname("开发部");
e.setDept(d);
List<Emp>empList=mapper.selectByLikeTwo(e);
for(Emp emp:empList){
System.out.println("所有开发部的员工:"+emp.getEname());
}
}
}
4.
<select id="selectByLikeName" resultType="org.mybatis.example.dao.Dept"
parameterType="org.mybatis.example.dao.Dept">
select d.deptno,d.dname,d.loc from dept d where
<if test="dname!=null">
1=1
</if>
<if test="dname!=null and dname!=''">
AND dname like #{dname}
</if>
</select>
测试类
public static void main(String[] args) {
SqlSession session=SqlSessionFactoryUtil.getSqlSession();
DeptMapper mapper=session.getMapper(DeptMapper.class);
Dept d=new Dept(); //或者设置为null
d.setDname("开发部");//设置为null的时候注释
List<Dept>deptList=mapper.selectByLikeName(d);
System.out.println(deptList.get(0).getDname());
}
5. foreach
动态SQL迭代一个集合,通常放在In条件语句中,foreach允许指定一个集合,声明集合项和索引变量,他们可以用在元素体内,也允许指定开放和关闭的字符串,在迭代之间放置分隔符。这个元素是智能的,不会偶然地附加多余的分隔符。
在EmpMapper.xml中增加代码段
<select id="selectDeptIn" resultType="org.mybatis.example.dao.Dept">
select * from dept d where deptno in
<foreach item="item" index="index" collection="list"
open="(" separator="," close=")">
#{item}
</foreach>
</select>
在接口EmpMapper.java中增加代码
public List<Dept> selectDeptIn(List<Integer>list);
测试类代码段
public class Test26 {
public static void main(String[] args) {
SqlSession session=SqlSessionFactoryUtil.getSqlSession();
DeptMapper mapper=session.getMapper(DeptMapper.class);
List<Integer>idList=new ArrayList<Integer>();
idList.add(5);
idList.add(6);
List<Dept>deptList=mapper.selectDeptIn(idList);
System.out.println(deptList.get(0).getDname());
System.out.println(deptList.get(1).getDname());
}
}
对于在Mybatis中出现的TooManyResultsException异常,需要将接口的方法返回类型修改为List<T>泛型类型即可。
mybatis.5.动态SQL的更多相关文章
- MyBatis的动态SQL详解
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑,本文详解mybatis的动态sql,需要的朋友可以参考下 MyBatis 的一个强大的特性之一通常是它 ...
- Mybatis解析动态sql原理分析
前言 废话不多说,直接进入文章. 我们在使用mybatis的时候,会在xml中编写sql语句. 比如这段动态sql代码: <update id="update" parame ...
- mybatis 使用动态SQL
RoleMapper.java public interface RoleMapper { public void add(Role role); public void update(Role ro ...
- MyBatis框架——动态SQL、缓存机制、逆向工程
MyBatis框架--动态SQL.缓存机制.逆向工程 一.Dynamic SQL 为什么需要动态SQL?有时候需要根据实际传入的参数来动态的拼接SQL语句.最常用的就是:where和if标签 1.参考 ...
- 使用Mybatis实现动态SQL(一)
使用Mybatis实现动态SQL 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 写在前面: *本章节适合有Mybatis基础者观看* 前置讲解 我现在写一个查询全部的 ...
- MyBatis探究-----动态SQL详解
1.if标签 接口中方法:public List<Employee> getEmpsByEmpProperties(Employee employee); XML中:where 1=1必不 ...
- mybatis中的.xml文件总结——mybatis的动态sql
resultMap resultType可以指定pojo将查询结果映射为pojo,但需要pojo的属性名和sql查询的列名一致方可映射成功. 如果sql查询字段名和pojo的属性名不一致,可以通过re ...
- MyBatis的动态SQL详解-各种标签使用
MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. MyBatis中用于实现动态SQL的元素主要有: if choose(when,otherwise) ...
- 利用MyBatis的动态SQL特性抽象统一SQL查询接口
1. SQL查询的统一抽象 MyBatis制动动态SQL的构造,利用动态SQL和自定义的参数Bean抽象,可以将绝大部分SQL查询抽象为一个统一接口,查询参数使用一个自定义bean继承Map,使用映射 ...
随机推荐
- spring 在ssh三大框架中充当的角色
https://blog.csdn.net/yeah_nn/article/details/79992777
- POJ 3164 Sunscreen (挑战程序设计竞赛的练习题)
题目:https://vjudge.net/problem/POJ-3614 思路参考这个:https://blog.csdn.net/qq_25576697/article/details/7657 ...
- thrift0.5入门操作
在探索未知的程序之前,我们往往会使用“Hello World”这个经典的输出作为测试,为了遵循这个惯例,作为thrift菜鸟都不算的一员,决定跑一下“Hello world”正式进入菜鸟的行列. th ...
- notion笔记
不错的笔记应用, 模式新颖, 正在使用, 如有相同使用者可以入群交流 notion QQ群 725638123
- OO学习第二阶段总结
面向对象课程的第二个阶段结束了,作业们由简单的玩具模式步入到复杂的多线程地狱模式,由之前的算法简单实现有坑转变成算法复杂实现有很大的坑.一个最重要的心得就是一定要在动手敲代码实现之前对整个程序的实现做 ...
- 求int型数组和最大子数组 续
之前的博文里已经实现过该程序的构思.编译.运行,本次就不再重复与之相雷同的内容. 题目:与别人借组,借助求int型数组最大和子数组的问题,考虑大数溢出和int取值范围的问题 要求: 调试程序 当子数 ...
- oracle 语句之对数据库的表名就行模糊查询,对查询结果进行遍历,依次获取每个表名结果中的每个字段(存储过程)
语句的执行环境是plsql的sql窗口, 语句的目的是从整个数据库中的所有表判断 不等于某个字段的记录数 . 代码如下: declare s_sql clob:=''; -- 声明一个变量,该变量用于 ...
- spring 原理
1.spring原理 内部最核心的就是IOC了,动态注入,让一个对象的创建不用new了,可以自动的生产,这其实就是利用java里的反射,反射其实就是在运行时动态的去创建.调用对象,Spring就是在运 ...
- Teamwork(The sixth day of the team)
每日列会过后,我们的工作进度都有所进展了,好开心,但是还不是我们想要的,我们想做得更快,更好.
- 用原生JS实现多张图片上传及预览功能(兼容IE8)
最近需要做一个图片上传预览的功能(兼容IE8-11.chrome.firefox等浏览器),网上现有的文件上传组件(如webuploader)总是会遇到一些兼容性问题.于是我参考了一些博文(链接找不到 ...