MyBatis完全使用指南
MyBatis完全使用指南
MyBatis作为一个轻量的SQL映射框架,确实很简单,但是知识点挺多,实际使用中还是会有时想不起来某个标签该怎么写,所以整理了这篇文章,以备查询。由于MyBatis如此简单,使得这一篇文章基本把实际使用中常碰到的事情都涵盖了,包括:
- MyBatis中的一些概念
- MyBatis包含的内容
- SQL映射
- 动态SQL
一、 MyBatis中的一些概念
1. MyBatis是个什么东西
在使用MyBatis的项目里,日志中往往会出现很多拼接SQL语句的log,这其实说明了MyBatis底层还是使用JDBC来实现的。在JDBC的基础上,为了性能考虑,所有的语句都是基于SqlSession。顾名思义,维护这个类的实例其实就是维护了一个对于某个数据库的连接的会话,在这个会话里可以有缓存啊什么之类的。
2. mapper接口是怎么映射成SQL语句的
目前多数开发者还是会使用XML来进行MyBatis的配置,包括MyBatis的核心配置和SQL映射配置。其实和注解一样,XML本身只不过是一个元数据的载体,最终起作用的还是MyBatis的核心类。其中有这样几个比较重要的:
SqlSessionFactoryBuilder,用来创建SqlSessionFactory的实例,之后就没有用了,其生命周期只是在初始化的时候有作用。SqlSessionFactory,MyBatis最基础的类,用来创建会话(即SqlSession的实例),其生命周期与整个系统的生命周期相同,在系统运行的任何时候都可以使用它查询到当前数据库的配置信息等。SqlSession,真正的和数据库之间的会话,线程不安全,所以其生命周期和使用它的线程相同。- 各种
Mapper,承载了实际的业务逻辑,其生命周期比较短,由SqlSession创建。
3. Spring环境中MyBatis的初始化过程
实际情况中MyBatis往往是在Spring的环境中使用的,MyBatis本身并不依赖Spring,但是使用Spring可以极大的提高开发效率,由于Spring进行了控制反转,所以其中MyBatis的初始化过程和正常过程稍稍有些不同:
- Spring发现需要创建
SqlSessionFactory实例,会在classpath下找到MyBatis的核心配置文件,使用它来初始化一个SqlSessionFactory实例。当然,这一步完全可以使用代码来完成,或者使用注解,就更加清晰明了。 - 往往mapper类也会作为bean注入到代码中去的,那么Spring会使用上一步中的
SqlSessionFactory实例来创建SqlSession的实例。 - 然后再使用
SqlSession尝试创建各个mapper对象。 - 于此同时,MyBatis会扫描classpath下的mapper映射XML文件(此路径可以自定义),对于每一个mapper接口,它的「类全名」会作为命名空间,来和映射文件中的mapper标签进行匹配。
- 对于每一个映射文件中的一个执行语句标签(如select、delete),MyBatis会把他们映射到
SqlSession的方法上,创建mapper接口的一个实现类。 - 如果mapper接口和其映射文件一一匹配,则bean创建成功。
二、MyBatis包含的内容
MyBatis本身就是一个简单的ORM框架,提供了SQL语句到方法、关系型数据表到对象的映射。实际使用中与开发者相关的有两个东西:
- MyBatis核心配置
缓存、数据源、日志等关系到MyBatis其本身行为的一些配置。 - mapper接口的映射
针对于具体业务逻辑的SQL映射。
三、SQL映射
MyBatis也可以使用注解来实现映射,对于简单的语句,使用注解可能会更加清晰简单,但是其真正强大的地方还是XML。
1. select
| 属性 | 描述 |
|---|---|
| id | 此命名空间内的标识符 |
| parameterType | 参数的类的全名或者alias,可选。默认为空。 |
| parameterMap | Deprecated |
| resultType | 返回结果的类型全名或alias,如果结果是集合,此类型表示的是集合的成员类型。 |
| resultMap | 使用指定的resultMap来映射结果集。resultMap 和 resultType只能二选一。 |
| flushCache | 如果为true,每次调用,一级缓存和二级缓存都会回写。select语句中默认为false。 |
| useCache | 如果为true,结果将在二级缓存中缓存。select语句中默认为true |
| timeout | 设置超时,若超时则抛出异常。 |
| fetchSize | 尝试在获取数据时分批获取。 |
| statementType | STATEMENT,PREPARED或者CALLABLE. 分别对应JDBC中的Statement,PreparedStatement和CallableStatement respectively。默认PREPARED. |
| resultSetType | FORWARD_ONLY,SCROLL_SENSITIVE或者SCROLL_INSENSITIVE。默认为空。 |
| databaseId | 使用特定的databaseIdProvider |
| resultOrdered | 嵌套查询时使用。 |
| resultSets | 多返回集合时使用。 |
2. 修改语句(insert,update,DELETE)
这3种语句的属性基本和上边select的一样,INSERT和UPDATE的语句有几个特殊的属性如下:
| 属性 | 描述 |
|---|---|
| useGeneratedKeys | 将使用JDBC的getGeneratedKeys方法来获取主键的值。默认为false。 |
| keyProperty | 主键。MyBatis会将生成的主键赋给这个列。联合主键使用逗号隔开。 |
| keyColumn | 特定数据库需要使用。 |
3. SQl语句段(sql标签)
<sql>标签可以定义一段sql语句段,可以在其他语句中引入使用。sql标签可以包含参数。示例如下:
<sql id="userColumns">${alias}.id,${alias}.username,${alias}.password </sql>
<select id="selectUsers" resultType="map">
select
<include refid="userColumns"><property name="alias" value="t1"/></include>,
<include refid="userColumns"><property name="alias" value="t2"/></include>
from some_table t1
cross join some_table t2
</select>
参数(property)也可以在refid或者include进来的sql中使用。示例如下:
<sql id="sometable">
${prefix}Table
</sql>
<sql id="someinclude">
from
<include refid="${include_target}"/>
</sql>
<select id="select" resultType="map">
select
field1, field2, field3
<include refid="someinclude">
<property name="prefix" value="Some"/>
<property name="include_target" value="sometable"/>
</include>
</select>
4. #{}和${}的区别
#{}在底层实现上使用?做占位符来生成PreparedStatement,然后将参数传入,大多数情况都应使用这个,它更快、更安全。${}将传入的数据直接显示生成在sql中。如:order by ${user_id},如果传入的值是111,那么解析成sql时的值为order by 111, 如果传入的值是id,则解析成的sql为order by id.
5. 类型别名
什么地方都少不了这种小技巧,可以让你少打很多字。
<typeAlias type="com.someapp.model.User" alias="User"/>
6. ResultMap
官方文档上说这个特性是整个MyBatis中最强大的特性(没有之一)。其实它做的就是映射结果集。
MyBatis底层使用JDBC,所以查询出来的结果是ResultSet,如果resultType是一个对象,MyBatis底层就会创建一个resultMap,并根据字段名一一对应上这个对象。如果你有一个查询,它的结果集非常复杂,可以使用resultMap来做映射。
cache和cach-ref
使用cache标签在映射文件内(某命名空间内)实现二级缓存,其所有属性都有缺省值,所以单单一个标签就可以生效。cach-ref可以在两个映射文件之间共享缓存
<cache
eviction="LRU"//缓存移除策略
flushInterval="60000"//默认不设置,不定时刷新
size="1024"
readOnly="false"/>
四、动态SQL
1. if
条件判断,参数为test
2. choose (嵌套when,otherwise)
多选一,参数为test
3. trim (where,set)
- trim标签可以定制其他标签,并且去头去尾;
- where标签会自动生成where语句,并且可以去除头部的and或者or;
- set标签可以自动生成set语句,并且可以去除尾部的逗号。
4. foreach
循环集合输出,可以循环数组,Iterable对象,或者Map,如果是Map,则index会是key。
<foreach item="item" index="index" collection="list"
open="(" separator="," close=")">
#{item}
</foreach>
5. bind
声明一个使用OGNL表达式生成的变量,在sql语句中使用。
MyBatis完全使用指南的更多相关文章
- [原创]Spring Boot + Mybatis 简易使用指南(一)基础环境搭建
前言 作者: Ant QQ:517377100 相对于使用JdbcTemplate,Mybatis可自动建立pojo类型与数据库列的映射关系,数据库访问层的开发简单了许多 所有数据库访问操作,均封装在 ...
- [原创]Spring Boot + Mybatis 简易使用指南(二)多参数方法支持 与 Joda DateTime类型支持
前言 今天在开发练习项目时遇到两个mybatis使用问题 第一个问题是mapper方法参数问题,在参数大于一个时,mybatis不会自动识别参数命名 第二个问题是Pojo中使用Joda DateTim ...
- Mybatis快速入门指南
简介 当下越来越多的企业项目架构中,在持久层部分,抛弃了Hibernate框架,而选用Mybatis框架取而代之,旨在更加深入细致的控制和数据库的交互. MyBatis 本是apache的一个开源项目 ...
- MyBatis 3 User Guide Simplified Chinese.pdf
MyBatis 3 用户指南 帮助我们把文档做得更好… 如果你发现了本文档的遗漏之处,或者丢失 MyBatis 特性的说明时,那么最好的方法就 是了解一下这个遗漏之处然后把它记录下来. 我们在 wik ...
- MyBatis(3)——配置解析
MyBatis中文参考指南:MyBatis用户指南 //------------核心配置文件说明------------// //*在注释中进行说明 <configuration> < ...
- Spring Boot + Mybatis + Redis二级缓存开发指南
Spring Boot + Mybatis + Redis二级缓存开发指南 背景 Spring-Boot因其提供了各种开箱即用的插件,使得它成为了当今最为主流的Java Web开发框架之一.Mybat ...
- 关于mybatis 的mapper namespace 作用及解析
因为语言惯性,大部分的namespace 在语言级别*来说是作为一种限定性标识来用,起到唯一或一类的标识.来看看语言(以PHP语言为例)上的namespace的作用实例 一.namespace 在PH ...
- 学习myBatis - 如何配置myBatis
这篇文章主要学习如何配置myBatis. 要学习新东西要讲究方法,要从三个层面去理解它:它是什么(what),为什么要学它(why),怎么用它(how).有了学习方法学习的效率才高. 1.myBati ...
- 配置MyBatis
创建WebProject之后先把mybatis-3.2.2.zip里的mybatis-3.2.2.jar包和lib里的asm-3.3.1.jar.cglib-2.2.2.jar.commons-log ...
随机推荐
- 网络编程(学习整理)---3--(Udp)FeiQ实现广播消息群发
1.广播群发消息: 这里使用的任然是UDP协议,使用方法还是比较简单的! 我就记录一下需要注意的一些地方(笔记): (1)这里是在局域网内,借用FeiQ聊天软件,编写一段程序,实现对局域网内的每一个登 ...
- [C#学习]在多线程中如何调用Winform[转]
问题的产生: 我的WinForm程序中有一个用于更新主窗口的工作线程(worker thread),但文档中却提示我不能在多线程中调用这个form(为什么?),而事实上我在调用时程序常常会崩掉.请问如 ...
- js 中对象属性的特性
数据属性: 数据属性包含一个数据值的位置,在这个位置可以读取和写入值. 4个描述的行为特性: writable 表示能否修改属性的值.默认为true Enumerable 表示能否过过for in循 ...
- 桂电在线-php-提取菜单到配置文件2
继续昨晚没完成的主菜单模板: <!-- 菜单块 --> <div class="on-light" id="menus"> <?p ...
- 通过try、except和else的使用来使Python程序更加“强壮”
在执行的程序中,难免会碰到因为一些原因如输入输出导致致命性错误产生的情况(如因为输入的文件名错误而导致无法运行相关的代码.).此时你不希望程序直接挂掉,而是通过显示一些信息,使其平稳的结束.此时,就可 ...
- gnuplot使用
直接用yum安装gnuplot即可,例如 sudo sh -c "yum install gnuplot.x86_64 " 安装以后就可以使用了 编写gnuplot脚本 # grp ...
- eclipse + maven + jboss 遇到ClassNotFoundException
在使用eclipse + maven + jboss开发过程中,碰到ClassNotFoundException, 原因应该是deployed包中未包含maven的依赖jar. 可以通过如下方法把依赖 ...
- linux下安装MySQL5.6记录
把之前装的mysql卸载了,准备重新用代码包装一遍,问了一下公司的DBA,他推荐给我mysql-5.6.16版本,说这个版本比较稳定. 按照网上的教程安装,结果就少文件,我还在找原因的时候,同事来找我 ...
- 转:实用 .htaccess 用法大全
原文来自于:http://www.techug.com/htaccess-snippets 这里收集的是各种实用的 .htaccess 代码片段,你能想到的用法几乎全在这里. 免责声明: 虽然将这些代 ...
- 【关于JavaScript】常见表单用户名、密码不能为空
在论坛等系统的用户注册功能中,如果用户忘记填写必填信息,如用户名.密码等,浏览器会弹出警告框,提示用户当前有未填信息. 这个典型的应用就是通过JavaScript实现的.如图所示是一个简单的用户注册页 ...