前置内容
- Java SE(尤其是Java与数据库的连接)
- 知道XML文档的特点以及语法
- Maven
第一部分 初识Mybatis
Mybatis是一个ORM持久层框架。它的前身是Ibatis。
什么是持久层?
持久层可以理解成数据存储在磁盘或者数据库等不易丢失的介质。ORM持久层是一种对象到数据库之间的持久层。
Mybatis就是这样的一个持久层框架。Mybatis是一种半自动映射的框架。它支持sql语句、存储过程以及高级映射。
Mybatis工作原理
- 读取mybatis配置文件。
- 加载映射文件(Mapper接口的映射文件)
- 构建会话工厂
- 通过工厂建立会话
- 通过会话执行Mapper接口中的方法实现对数据库的操作
MyBatis下载和导入
下载地址:https://github.com/mybatis/mybatis-3/releases
解压下载的zip,在解压的文件中找到lib文件夹,这里面的文件就是需要的jar包了,将他们全部放在项目中并启用,然后返回上一级,将mybatis-x.x.x.jar放入到项目中并启用。如何导入jar包这里不过多赘述。
如果你使用maven,可以将下面代码输入到项目中的pom.xml文件中的<dependencies>节点下。
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.32</version>
</dependency>
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.14.1</version>
</dependency>
<dependency>
<groupId>ognl</groupId>
<artifactId>ognl</artifactId>
<version>3.2.21</version>
</dependency>
第二部分 全局配置文件
说明:
配置文件这部分只要知道常用节点是干什么的同时知道自己复制粘贴配置文件时应该改哪里就可以了。并不要求掌握配置文件怎么写。(也没必要掌握怎么写,毕竟到后面学习Springboot后就用不到这个配置文件了)
Mybatis的全局配置文件是使用Mybatis的基础。在创建全局配置文件之前,我们需要将约束文件添加进ide中以获得一些语法提示。这里ide使用idea。(如果不想获得语法提示可以跳过这部分,直接从第三步开始)
- 先将mybatis-x.x.x.jar用解压缩软件打开,找到org/apache/ibatis/builder/xml,将两个dtd文件解压出来。
- 打开idea的设置(关闭项目后打开),找到“语言和框架”-》“架构和DTD”,点击左上角的加号,uri写
http://mybatis.org/dtd/mybatis-3-config.dtd
文件那一栏选择刚才解压出来的mybatis-3-config.dtd
(一定要仔细确定文件名),点击确定,再点击加号,uri输入http://mybatis.org/dtd/mybatis-3-mapper.dtd
,文件那一栏选择mybatis-3-mapper.dtd
,点击确定,再点击确定。 - 打开项目,在src目录下新建一个名为mybatis.xml的文件。(如果使用maven导包,需要在src/main/resources文件夹下创建)。输入下面代码:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value=""/>
<property name="url" value=""/>
<property name="username" value=""/>
<property name="password" value=""/>
</dataSource>
</environment>
</environments>
<mappers>
<package name="com.blacol.mapper"/>
</mappers>
</configuration>
其中<configuration>
是配置文件中的根节点,该节点内的所有标签都称为子节点,常用子节点列在下表:
节点名 | 功能 |
---|---|
<properties> |
是否引入外部的配置文件。如果将一些信息比如数据库驱动、数据库连接、数据库密码等存储在了外部的一个文件中需要使用这个节点 |
<settings> |
改变mybatis的行为 |
<typeAliases> |
配置类型映射,用于抽象数据类型的名称的简化。 |
<environments> |
配置mybatis执行环境 |
<mappers> |
配置映射路径,在程序启动时mybatis会检查该节点下配置的路径中的@Mapper注解 |
其中environment和mappers是最重要的配置文件节点。
Environments节点
这里常用于配置数据库连接信息。通过上面的代码来解释各个部分。
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value=""/>
<property name="url" value=""/>
<property name="username" value=""/>
<property name="password" value=""/>
</dataSource>
</environment>
</environments>
节点 | 作用 | 允许的值 |
---|---|---|
environment | 编写一个运行环境,id为唯一标识符 | |
transcationManager | 配置事务管理器 | JDBC、MANAGED |
dataSource | 数据源类型 | POOLED、UNPOOLED、JNDI |
property | 数据源属性(如链接地址、用户名和密码等) |
事务管理器
一般使用JDBC即可,因为在实际的SSM项目中会使用Spring自带的管理器来实现事务管理。
数据源类型
最常用的是POOLED。它可以使并发Web项目可以更快速的请求。
UNPOOLED类型在程序每次被请求都会打开数据库的连接。这很浪费性能。
JNDI可以在EJB或者应用服务器等容器中使用。(现在已经不常用了)
数据源属性
包括连接数据库的连接、用户名、密码、驱动。其中,name属性的值是不能变的(必须是driver,url,username,password。如果将driver改成诸如mydriver之类的自定义名称则会报错)
value属性就是对应name的值。
Mappers节点
用于告诉Mybatis你的Mapper接口在哪里。一般使用<package>
标签去指定包名即可。如<package name="com.blacol.project1.mapper"/>
就是告诉Mybatis在com.blacol.project1.mapper
这个包(包括其子包)下面有Mapper接口。
如果你的Mapper接口在多个包中你可以使用多个package标签(一般没人会这么做)。
总结
本篇介绍了Mybatis的工作原理以及配置方法。这些内容为后面的mybatis应用做了铺垫。## 前言
上一章介绍了