《深入浅出MyBatis技术原理与实战》——4. 映射器,5. 动态SQL
4.1 映射器的主要元素


4.2 select元素



4.2.2 简易数据类型的例子
例如,我们需要统计一个姓氏的用户数量。应该把姓氏作为参数传递,而将结果设置为整型返回给调用者,如:


4.2.3 自动映射
当参数autoMappingBehaviour不设置为NONE的时候,MyBatis会提供自动映射的功能,只要返回的SQL列名和JavaBean的属性一致,MyBatis就会帮助我们回填这些字段而无需任何配置。比如:

4.2.4 传递多个参数
4.2.4.1 使用Map传递参数:

对于RoleDao接口,我们提供一个方法:

然后输入上面的代码就可以使用这个方法了:

这个方法虽然简单易用,但是有一个弊端:这样设置的参数使用了Map,而Map需要键值对应,由于业务关联性不强,你需要深入到程序中看代码,造成可读性下降。
4.2.4.2 使用注解方式传递参数
使用iBatis的参数注解@Param(org.apache.ibatis.annotations.Param)来实现想要的功能,把RoleDao接口修改为下面的形式:

再把映射器的XML修改为无需定义参数类型,如:

可读性虽然大大提高,但是如果一条SQL拥有10个参数的查询,如果我们都使用@Param方式,那么参数将十分复杂。
4.2.4.3 使用JavaBean传递参数
在参数过多的情况下,MyBatis允许组织一个JavaBean,通过简单的setter和getter方法设置参数。首先,定一个RoleParams的JavaBean,如:

用JavaBean改写一下传递参数的例子:

同样我们要在RoleDao接口提供一个方法:

4.2.4.4 总结

4.2.5 使用resultMap映射结果集
某些时候,我们需要处理更为复杂的映射,resultMap为我们提供了这样的模式。我们需要在映射器中定义resultMap,这也是常见的场景:


4.3 insert元素
4.3.1 概述
4.3.2 主键回填和自定义
可以使用keyProperty属性指定哪个是主键字段,同时使用useGeneratedKeys属性告诉MyBatis这个主键是否使用数据库内置策略生成。

上面指定了id列是主键,自增字段。但是实际工作往往需要根据一些特殊的关系设置主键id的值,假设我们取消表t_role的id自增规则,要求是:如果表t_role没有记录,则我们需要设置id=1,否则我们就取最大id加2来设置新的主键。这个时候可以使用selectKey元素处理,如:


4.4 update元素和delete元素
4.5 参数
需要强调的一点是:定义参数属性的时候,MyBatis不允许换行!
4.5.1 参数配置
可以传入一个简单的参数,比如int,double,也可以传入JavaBean。有时候需要处理一些特殊的情况,可以指定特定的类型,以确定使用哪个typeHandler处理它们,以便我们进行特殊处理:

4.5.2 存储过程支持
对于存储过程而言,存在3中参数,输入参数(IN)、输出参数(OUT)、输入输出参数(INOUT)。通过指定mode属性来确定是哪一种参数,选项有3种:IN、OUT、INOUT。
4.5.3 特殊字符串替换和处理(#和$)
4.6 sql元素
我们可以定义一串SQL语句的组成部分,其他的语句可以通过引用来使用它,从而避免重复的SQL语句。如:

4.7 resultMap结果映射集
作用是定义映射规则,级联的更新,定制类型转化器等。
4.7.1 resultMap元素的构成

4.7.2 使用map存储结果集
4.7.3 使用POJO存储结果集
POJO是我们最常用的方式,使用前需要配置resultMap,如:

接着我们在映射文件的select元素里面做如下的配置便可以使用了:

4.7.4 级联
rsultMap的级联分为3种:association、collection和discriminatior。


4.7.4.4 性能分析和N+1问题
4.4.7.5 延迟加载
意义在于,一开始并不取出级联数据,只有当使用它才发送SQL去取回数据。在MyBatis的配置中有两个全局的参数lazyLoadingEnabled和aggressiveLazyLoading。LazyLoadingEnabled的含义是是否开启延迟加载,aggressivaLazyLoading的含义是对任意延迟属性的调用会使带有延迟加载属性的对象完整加载,反之,每种属性将按需加载。
4.8 缓存cache
4.8.1 系统缓存(一级缓存和二级缓存)
没有配置的默认情况下,只开启一级缓存。所以在参数和SQL完全一样的情况下,我们使用同一个SqlSession对象调用同一个Mapper的方法,往往值执行一次SQL,因为第一次的查询结果会放在缓存中,如果没有声明需要刷新,并且缓存没有超时的情况下,SqlSession都只会取出当前缓存的数据,而不会再次发送SQL到数据库。一级缓存在各个SqlSession是相互隔离的,为了克服这个问题,我们往往需要配置二级缓存,使得缓存在SqlSessionFactory层面上能够提供给各个SqlSession。实现二级缓存的时候,MyBatis要求返回的POJO必须是可序列化的。配置的方法很简单,只需要在映射XML文件配置就可以开启了。

4.8.2 自定义缓存
系统缓存是MyBatis应用机器上的本地缓存,但是在大型服务器上,会使用各类不同的缓存服务器,这个时候我们可以定制缓存,比如Redis缓存。我们需要实现MyBatis为我们提供的接口org.apache.ibatis.cache.Cache,缓存接口简介如下:

可以配置SQL层面上的缓存规则,决定是否需要或者刷新缓存:

5.1 动态SQL概述
MyBatis的动态SQL包括以下几种元素:

5.2 if元素

5.3 choose、when、otherwise元素

5.4 tirm、where、set元素
5.5 foreach元素、test的属性、bind元素
《深入浅出MyBatis技术原理与实战》——4. 映射器,5. 动态SQL的更多相关文章
- 《深入浅出MyBatis技术原理与实战》——6. MyBatis的解析和运行原理
MyBatis的运行分为两大部分,第一部分是读取配置文件缓存到Configuration对象,用以创建SqlSessionFactory,第二部分是SqlSession的执行过程. 6.1 涉及的技术 ...
- 《深入浅出MyBatis技术原理与实战》——3. 配置
要注意的是上面那些层次是不能够颠倒顺序的,否则MyBatis在解析文件的时候就会出现异常. 3.1 properties元素 properties是一个属性配置元素,让我们能在配置文件的上下文中使用它 ...
- 《深入浅出MyBatis技术原理与实战》——1.简介,2.入门
1. 简介 Java程序都是通过JDBC连接数据库,但是只定义了接口规范,具体的实现交给各个数据库厂商去实现,因为每个数据库都有其特殊性.所以JDBC是一种桥接模式. 这里为什么说JDBC是一种桥接模 ...
- 深入浅出MyBatis技术原理与实战
第1 章 MyBatis 简介..................................................................................... ...
- 《深入浅出MyBatis技术原理与实战》——7. 插件
在第6章讨论了四大运行对象的运行过程,在Configuration对象的创建方法里我们看到了MyBatis用责任链去封装它们. 7.1 插件接口 在MyBatis中使用插件,我们必须使用接口Inter ...
- 深入浅出Mybatis技术原理与实战(杨开振)(带详细书签) PDF 下载 高清 完整版+源码
(杨开振) 源码 IDE eclipse 建表语句也在里面 电子书+源码地址
- 2017.2.9 深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二)-----配置文件详解
深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二) ------配置文件详解 8.2 MyBatis-Spring应用 8.2.1 概述 本文主要讲述通过注解配置MyBa ...
- 2MyBatis入门--深入浅出MyBatis技术原理与实践(笔记)
什么是 MyBatis ? MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis ...
- 3MyBatis配置--深入浅出MyBatis技术原理与实践(笔记)
XML 映射配置文件 configuration 配置 properties 属性 settings 设置 typeAliases 类型命名 typeHandlers 类型处理器 objectFact ...
随机推荐
- syslog服务器配置笔记
syslog服务器可以用作一个网络中的日志监控中心,rsyslog是一个开源工具,被广泛用于Linux系统以通过TCP/UDP协议转发或接收日志消息.本文我们来讲讲在 Linux 上配置一个 sysl ...
- POJ.3624 Charm Bracelet(DP 01背包)
POJ.3624 Charm Bracelet(DP 01背包) 题意分析 裸01背包 代码总览 #include <iostream> #include <cstdio> # ...
- 【二分】【P1314】 【NOIP2011D2T2】聪明的质监员
传送门 Description 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 \(n\) 个矿石,从 \(1\) 到 \(n\) 逐一编号,每个矿石都有自己的重量 \(w_i\) ...
- MySQL5.7 添加、删除用户与授权
mysql -uroot -proot 例子: 创建用户mysql> CREATE USER 'xiaoyaoji'@'%' IDENTIFIED BY 'xiaoyaoji';Query OK ...
- HDU 2852 主席树
KiKi's K-Number Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- ClusterId read in ZooKeeper is null 处理
ClusterId read in ZooKeeper is null. Re-running the program after fixing issue 1 will result in the ...
- Java设计模式の观察者模式(推拉模型)
目录: 一.观察者定义 二.观察者模式的结构(推模式实现) 三.推模型和拉模型(拉模式实现) 四.JAVA提供的对观察者模式的支持 五.使用JAVA对观察者模式的支持(自带推模式实现实例) 一.观察者 ...
- PHP日期时间操作
一.设置时区 date_default_timezone_set('PRC'); 二.获取当前时间的 Unix 时间戳(格林威治时间 1970 年 1 月 1 日 00:00:00到当前时间的秒数)和 ...
- Spring与MyBatis的整合(山东数漫江湖)
首先看一下项目结构图: 具体步骤如下: 1.建立JDBC属性文件 jdbc.properties (文件编码修改为 utf-8 ) driver=com.mysql.jdbc.Driver url=j ...
- MSSQL DBcheck
--1.创建数据库. --create database MyDatabase; --删除数据库 --drop database MyDatabase; ----------------------- ...