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即可,解压后得到如图所示的目录。
图中的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的工作原理如图所示。
下面对图中的每步流程进行说明。
(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的顾客表。然后往里插入数据。
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中的大概倒数第二页,内容如图:
将他复制粘贴到你的log4j.properties中,稍加修改
然后在src中建一个包,名字就为我圈的那个
接下来新建一个类,类名和数据库名相同。
书写与数据库名字一样的属性(一定要和数据库字段名一致)然后生成右键source生成get set方法以及toString方法
1 | package com.dm.po; |
保存接下来新建一个xml文件,名字自定义。
里头的内容还是在那个mybatis的pdf中去找大概在文章的2.1.5章节处
复制粘贴到你新建的xml文件中。
进行更改
1 |
|
然后在src包下建立mybatis-config.xml大概内容在pdf2.1.2章节下
代码如下:
1 |
|
接下来创建测试类:
MybatisTest.java
1 | package com.dm.po.test; |
在最后测试报错因为版本问题所以建议大家下载低版本例如mybatis-3.4.5,更换了mybatis版本后,代码成功运行。
运行结果: