MyBatis框架入门

1. MyBatis框架简介

MyBatis本是Apache的一个开源项iBatis, 2010 年这个项目由Apache SoftwareFoundation迁移到了Google Code,并且改名为MyBatis.
MyBatis是一个基于 Java的持久层框架。MyBatis提供的持久层框架包括SQL Maps和Data Access Objects (DAO),它消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs (Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。
目前,Java 的持久层框架产品有许多,常见的有Hibernate和MyBatis。MyBatis 是一 个半自动映射的框架,因为MyBatis需要手动匹配POIO、SQL 和映射关系:而Hibernate是一个全表映射的框架,只需提供POJO和映射关系即可。MyBatis 是一个小巧、 方便、高效、简单、直接、半自动化的持久层框架: Hibernate是一 个强大、方便、高效、复杂、间接、全自动化的持久层框架。两个持久层框架各有优缺点,开发者应根据实际应用选择它们。

2. MyBatis环境的构建

(在最后测试报错因为版本问题所以建议大家下载低版本例如mybatis-3.4.5)
MyBatis的3.5.3版本可以通过“https://github.com/mybatis/mybatis-3/releases"网址下载。在下载时只需选择mybatis-3.5.3.zip即可,解压后得到如图所示的目录。

image-20191108102813187
图中的mybatis-3.5.3.jar是MyBatis的核心包,mybatis-3.5.3.pdf 是MyBatis的使用手册,lib文件夹下的JAR是MyBatis的依赖包。
在使用MyBatis框架时需要将它的核心包和依赖包引入到应用程序中。如果是Web应用,只需将核心包和依赖包复制到/WEB-INF/lib目录中。

3. MyBatis的工作原理

在学习MyBatis程序之前,读者需要了解一下MyBatis的工作原理,以便于理解程序。MyBatis的工作原理如图所示。

image-20191108111228137

下面对图中的每步流程进行说明。
(1)读取MyBaits配置文件: mybatis-config.xml为MyBatis的全局配置文件,配置了MyBatis的运行环境等信息,例如数据库连接信息。

(2)加载映射文件。映射文件即SQL映射文件,该文件中配置了操作数据库的SQL语句,需要在MyBatis配置文件mybatis-config.xml中加载。mybatis-config.xml文件可以加载多个映射文件,每个文件对应数据库中的一张表

(3)构造会话工厂:通过MyBatis的环境等配置信息构建会话工厂SqlSessionFactory。

(4) 创建会话对象:由会话工厂创建SqlSession对象,该对象中包含了执行SQL语句的所有方法。

(5) Executor 执行器: MyBatis 底层定义了-一个Executor 接口来操作数据库,它将根据SqlSession传递的参数动态地生成需要执行的SQL语句,同时负责查询缓存的维护。

(6) MappedStatement对象:在Executor 接口的执行方法中有一个MappedStatement类型的参数,该参数是对映射信息的封装,用于存储要映射的SQL语句的id、参数等信息。

(7) 输入参数映射:输入参数类型可以是Map、List等集合类型,也可以是基本数据类型和POJO类型。输入参数映射过程类似于JDBC对preparedStatement对象设置参数的过程。

(8) 输出结果映射:输出结果类型可以是Map、List 等集合类型,也可以是基本数据类型和POJO类型。输出结果映射过程类似于JDBC对结果集的解析过程。

4. 实例

4.1 创建数据库

创建一个名为customer的顾客表。然后往里插入数据。

image-20191003114419490

image-20191003114637484

4.2 创建工程

名字随便起了,接下来导入核心jar包,你下载的文件中lib所有包以及mybatis-3.5.3.jar还有mysql数据库连接包mysql-connector-java-5.1.28-bin.jar。

在src目录下新建一个log4j.properties,具体内容为你下载的文件中mybatis-3.5.3.pdf中的大概倒数第二页,内容如图:

image-20191003120508187

将他复制粘贴到你的log4j.properties中,稍加修改image-20191003121156831

然后在src中建一个包,名字就为我圈的那个

接下来新建一个类,类名和数据库名相同。

image-20191003121419860

书写与数据库名字一样的属性(一定要和数据库字段名一致)然后生成右键source生成get set方法以及toString方法

image-20191003121809830
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
package com.dm.po;
/*

*
* 客户持久类
*/
public class Customer {
private Integer id;
private String username;
private String jobs;
private String phone;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getJobs() {
return jobs;
}
public void setJobs(String jobs) {
this.jobs = jobs;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
@Override
public String toString() {
return "Customer [id=" + id + ", username=" + username + ", jobs="
+ jobs + ", phone=" + phone + "]";
}

}

保存接下来新建一个xml文件,名字自定义。

里头的内容还是在那个mybatis的pdf中去找大概在文章的2.1.5章节处

image-20191003122521257

复制粘贴到你新建的xml文件中。

进行更改

1
2
3
4
5
6
7
8
9
10
11
12
<?xml version="1.0" encoding="UTF-8" ?> 
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace为命名空间 -->
<mapper namespace="com.dm.po.Customer">
<!-- 根据编号获取客户信息 -->
<select id="findCustomerByID" parameterType="Integer" resultType="com.dm.po.Customer">
<!-- #{id}相当于? -->
select * from customer where id = #{id}
</select>
</mapper>

然后在src包下建立mybatis-config.xml大概内容在pdf2.1.2章节下image-20191003124017773

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<?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>
<!-- 配置环境 默认的环境 id为 mysql -->
<environments default="mysql">
<environment id="mysql">
<!-- 使用JDBC的事务管理 -->
<transactionManager type="JDBC" />
<!-- 数据库连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
<property name="username" value="root" />
<property name="password" value="123456" />
</dataSource>
</environment>
</environments>
<!-- 配置mapper的位置 -->
<mappers>
<mapper resource="com/dm/po/CustomerMapper.xml" />
</mappers>
</configuration>

接下来创建测试类:

MybatisTest.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package com.dm.po.test;



import java.io.IOException;
import java.io.InputStream;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;


import com.dm.po.Customer;

/*
* 入门程序测试:
* */
public class MybatisTest {
public static void main(String[] args) throws IOException {
//1.读取配置文件
String resource="mybatis-config.xml";
InputStream inputStream =Resources.getResourceAsStream(resource);
//2.根据配置文件构建SqlSessionFactory
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
//3.通过sqlsessionFactory构建sqlsession
SqlSession sqlSession=sqlSessionFactory.openSession();
//4.sqlsession执行映射文件中定义的Sql,并返回映射结果
//第一个参数是sql的id,第二个参数是传入给sql的占位符参数
Customer customer=sqlSession.selectOne("com.dm.po.Customer.findCustomerByID",1);
//打印输出结果
System.out.println(customer.toString());
//5.关闭sqlsession
sqlSession.close();

}


}

在最后测试报错因为版本问题所以建议大家下载低版本例如mybatis-3.4.5,更换了mybatis版本后,代码成功运行。

运行结果:

image-20191003143848961

-------------本文结束感谢您的阅读-------------
0%