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,使用映射 ...
随机推荐
- python的eval和json.loads(),json.dumps()
eval() 将字符串当成一个表达式去执行,可以想象成一个去字符串然后执行的操作. In [1]: s = '3*8' In [2]: eval(s) Out[2]: 24 eval()和json.l ...
- Netty源码分析第1章(Netty启动流程)---->第5节: 绑定端口
Netty源码分析第一章:Netty启动步骤 第五节:绑定端口 上一小节我们学习了channel注册在selector的步骤, 仅仅做了注册但并没有监听事件, 事件是如何监听的呢? 我们继续跟第一小节 ...
- 【python 3.6】类:访问属性及调用方法
>>> class price(): //定义1个类,用于计算价格 def __init__(self,name,danjia): //初始化方法,定义商品名称和单价 self.na ...
- python基础知识-11-函数装饰器
python其他知识目录 1.装饰器学习前热身准备 1.1装饰器简介 1.2装饰器热身分析 ) def func(): pass v1 = v2 = func #将函数名赋予一个变量,就和变量赋值是同 ...
- 第十二周作业_PSP总结报告
回顾1 (1)回想一下你曾经对计算机专业的畅想 当初你是如何做出选择计算机专业的决定的?经过一个学期,你的看法改变了么,为什么? 你认为过去接触到的课程是否符合你对计算机专业的期待,为什么?经过一个学 ...
- Final发布用户使用报告 -- Thunder团队
Thunder爱阅app Final发布用户使用报告 用户数量:14人 以下为用户评论:(注:为了保护用户的姓名权,以下用户名以昵称形式给出.) 序列 昵称 个人信息 获得软件途径 使用次数 用户评论 ...
- Sprint11
进展:基本设置和显示已经完成,然后是可以通过长按事件弹出对话框可以进行停用.修改.取消该事件提醒的实现,通过触发动作跳转到各个部分页面.
- jquery-numberformatter插件
项目地址:https://code.google.com/p/jquery-numberformatter/ 非jquery版:https://github.com/andrewgp/jsNumber ...
- Java Head First & 多态
package com.cwcec.tag; class Fruit { } class Apple extends Fruit{} class Animal { public Fruit eat(F ...
- Delphi 判断TImage是否为空及注意事项
Delphi 判断TImage是否为空:1)非空 Image1.Picture.Graphic <> nil2)为空 Image1.Picture.Graphic = nil注意不能用Im ...