Mybatis框架简介、搭建及核心元素揭秘
大家都知道当前比较流行的框架,如Spring、SpringMVC、Hibernate、Mybatis等框架,那今天咱们来讲讲当前比较流行的企业框架Mybatis。
首先先来介绍一下Mybatis这个框架:Mybatis是一个开源的数据持久化层框架,它内部封装了通过JDBC访问数据库的操作,支持普通的SQL查询,存储过程和高级映射,几乎消除了所有的JDBC代码和参数设置及结果集的检索。
接下来说说Mybatis的优缺点:
优点:与JDBC相比,减少了50%以上的代码量,最简单的持久化框架,小巧简单易学,SQL代码从程序中彻底分离,可重用。提供了XML标签,支持编写动态SQL,提供映射标签,支持对象与数据库的ORM字段映射。那么什么是ORM呢?
ORM(Object RelationMapping)即对象关系映射,是一种数据持久化技术,它在对象模型和关系型数据库之间建立对应关系。
接下来说说Mybatis的缺点:
SQL语句编写量大,对于开发人员有一定的要求,数据库移植性差
Mybatis的环境搭建
首先我们的去Mybatis的官方网站(http://mybatis.org)下载最新Release版本的Mybatis
压缩包解压后可以看到一下的目录结构
- lib
- LICENSE
- mybatis-3.2.2.jar
- mybatis-3.2.2.pdf
- NOTICE
在根目录下存放着mybatis-3.2.2.jar,为Mybatis的jar文件,Mybatis-3.2.2.pdf为Mybatis官方使用文档
lib目录下存放着编译依赖包,接下来来介绍一下Mybatis编译的依赖包
- asm-3.3.1.jar:操作Java字节码的类库
- cglib-2.2.2.jar:用来动态集成Java类或实现接口
- commons-logging-1.1.1.jar:用于通用日志处理
- javassist-3.17.1-GA。jar:分析、编辑和创建java字节码的类库、
- log4j-1.2.17.jar:日志系统
- slf4j-api-1.7.5.jar:日志系统的封装,对外提供统一的API接口
- slf4j-log4j12-1.7.5.jar:slf4j对log4j的相应驱动,完成slf4j绑定log4j
其次是mybatis-3-mybatis-3.2.2.zip(Mybatis源码包):里面是Mybatis的所有源代码
目录结构就讲到这,至于具体创建Mybatis项目在这我就不多说了
接下来再介绍一下Mybatis的核心配置文件configuration.xml
Mybatis核心配置文件主要用于配置数据库连接和Mybatis运行时所需要的各种特性,包含了设置和影响Mybatis行为的属性
接下来说说配置文件中的基本要素
<?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>
<!-- 引入database.properties -->
<properties resource="database.properties"/>
<!-- 配置mybatis的log实现LOG4J -->
<settings>
<setting name="logImpl" value="LOG4J"/>
</settings>
<!-- 配置mybatis多套运行环境 -->
<environments default="development">
<environment id="development">
<!-- 配置事务管理,采用JDBC的事务管理 -->
<transactionManager type="JDBC"></transactionManager>
<!-- POOLED:mybatis自带的数据源,JNDI:基于Tomcat的数据源 -->
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!-- 将mapper文件加入到配置文件中 -->
<mappers>
<mapper resource="POJO/UserMapper.xml"/>
</mappers>
</configuration>
mybatis-config.xml文件的几个常用元素的作用如下:
- configuration:配置文件的根元素节点
- properties:通过resource属性从外部指定properties属性文件(database.properties),该属性文件描述数据库连接的相关配置(数据库驱动、连接数据库的url、数据库用户名、数据库密码),位置也是在/resource目录下。
- settings:设置Mybatis运行中的一些行为,比如此处设置Mybatis的log日志实现为LOG4J,即使用log4j实现日志功能。
- environments:配置Mybatis的多套运行环境,将SQL映射到多个不同的数据库上,该元素节点下可以配置多个environment子元素节点,但是必须指定其中一个默认运行环境(通过default指定)。
- environment:配置Mybatis的一套运行环境,需指定ID、事务管理器、数据源配置等相关信息。
- mappers:作用是告诉Mybatis去哪里找到SQL映射文件(该文件内容是开发者定义的映射SQL语句),整个项目可以有1个或者多个SQL映射文件
- mapper:mappers的子元素节点,具体指定SQL映射文件的路径,其中resource属性的值表述了SQL映射文件的路径(类资源路径)
在这里我稍微提一下注意事项:mybatis-config.xml文件的元素节点是有一定的顺序,节点位置若不按照顺序排位的话,那么XML文件会报错,至于元素的排列顺序是:
1.properties
2.settings
3.typeAliases
4.typeHandlers
5.objectFactory
6.objectWrapperFactory
7.plugins
8.environments?
9.databaseIdProvider
10.mappers
常用元素
常用元素的顺序大致就是这样的,大家可以参考一下
有了Mybatis的核心配置文件后,接下来就要准备持久化类和SQL映射文件
那么什么是持久化类呢?持久化类是指其实例状态需要被Mybatis持久化到数据库中的类,在应用的设计中,持久化类通常对应业务中的业务实体,Mybatis一般采用POJO编程模型来实现持久化类,与POJO类配合完成持久化工作是Mybatis最常见的工作模式
既然都讲到这了,我就再讲讲什么是POJO吧!
POJO(Plain Ordinary Java Object):从字面上来说就是普通的Java对象,POJO类可以简单地理解为符合JavaBean规范的实体类,它不需要继承和实现任何特殊的Java基类或者接口,JavaBean对象的状态保存咋属性中,访问属性必须通过对应的getter和setter方法
POJO实体类
接下里我用实例来向大家演示一下
public class User {
private Integer id; //id
private String userCode; //用户编码
private String userName; //用户名称
private String userPassword; //用户密码
private Integer gender; //性别
private Date birthday; //出生日期
private String phone; //电话
private String address; //地址
private Integer userRole; //用户角色
private Integer createdBy; //创建者
private Date creationDate; //创建时间
private Integer modifyBy; //更新者
private Date modifyDate; //更新时间
//省略getter,setter方法
SQL映射文件
接下来,继续进行SQL映射文件的创建,完成与POJO(实体类)的映射,该文件也是一个XML文件,命名为UserMapper.xml,示例如下
<?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">
<mapper namespace="POJO.UserMapper">
<!-- 查询用户列表记录数 -->
<select id="count" resultType="int">
select count(1) as count from smbms_user
</select>
</mapper>
上面的代码就是所定义的SQL语句,其中元素的含义是
1.mapper:映射文件的根元素节点,只有一个属性namespace
- namespace:用于区分不同的mapper,全局唯一
2.select:表示查询语句,是Mybatis最常用的元素之一,常用属性如下
- id属性:该命名空间下唯一标识符
- resultType属性:表示SQL语句返回值类型,此处通过SQL语句返回的是Int数据类型
测试类
SQl映射文件也弄好了,接下来就是创建测试类了,具体的实现步骤:
1.读取全局配置文件:mybatis-config.xml
String resource="mybatis-config.xml";
//获取mybatis-config.xml文件的输入流
InputStream is=Resource.getResourceAsStream(resource);
2.创建SQLSessionFactory对象,此对象可以完成对配置文件的读写
SQLSessionFactory factory=new SqlSessionFactoryBuilder().build(is);
3.创建SQLSession对象,此对象的作用是调用mapper文件进行数据操作,需要注意的是必须先将mapper文件引入到mybatis-config.xml中才能起效
int count=0;
SqlSession sqlSession=null;
sqlSession=factory.openSession();
//Mybatis通过mapper文件的namespace和子元素的id来找到对应的SQL,从而执行查询操作
count=sqlSession.selectOne("cn.smbms.dao.user.UserMapper.count");
logger.debug("UserMapperTest count------>"+count);
4.关闭SqlSession对象
sqlSession.close();
上面咱们已经成功地将Mybatis搭建出来了,下面再来说说Mybatis的核心要素
核心要素
首先介绍一下Mybatis的核心接口和类
- 每个Mybatis的应用程序都以一个SQLSessionFactory对象的实例为核心
- 首先获取SqlSessionFactoryBuilder对象,可以根据XML配置文件或Configuration类的实例构建对象
- 然后获取SQLSessionFactory对象,该对象实例可以通过SqlSessionFactoryBuilder对象来获得
- 有了SQLSessionFactory对象之后,就可以进而获取SqlSession实例,SqlSession对象中完全包含以数据库为背景的所有执行SQL操作方法,可以用该实例来直接执行已映射的SQL语句
SqlSessionFactoryBuilder
SqlSessionFactoryBuilder负责构建SQLSessionFactory,并且提供了多个build()方法的重载,分别是
- InputStream(字节流)
- Reader(字符流)
- Configuration(类)
SqlSessionFactoryBuilder的生命周期和作用域
SqlSessionFactoryBuilder的最大特点就是:用过即丢。一旦创建了SQLSessionFactory对象之后,这个类就不再需要存在了,因此SqlSessionFactoryBuilder的最佳范围就是存在于方法体内,也就是局部变量而已。
SqlSessionFactory
SqlSessionFactory简单的理解就是创建SqlSession实例的工厂。所有的Mybatis应用都是以SQLSessionFactory实例为中心,SQLSessionFactory的实例可以通过SqlSessionFactoryBuilder对象来获取
SqlSessionFactory的生命周期和作用域
SqlSessionFactory对象一旦创建,就会在整个应用程序中始终存在。没有理由去销毁或再创建它,并且在应用程序运行中也不建议多次创建SQLSessionFactory,怎么说呢,你可以吧SqlSessionFactoryBuilder当做创建工厂的工人,而SQLSessionFactory就是创建好的工厂,一般来说工厂创建好了之后,工人就不需要了,而工厂会被保留下来,这就是它们的生命周期吧!
以上就是本文所介绍Mybatis的内容了,大致的核心都介绍完了,接下来你可以自己去消化一下,加油!