Mybatis是当今比较流行的、开源的数据持久化层(DAO)框架,作为SSM框架之一,它可以在实体类与SQL语句之间建立映射关系。
主要有以下优点:
- 与JDBC相比,减少了50%以上代码量
- 是最简单的持久化框架、小巧简单易学
- SQL代码从程序代码中彻底分离,可重用
- 提供XML标签,支持编写动态SQL
- 提供映射标签,支持对象与数据库的ORM字段关系映射
Mybatis有以下几个重要部分组成:
mybatis-config.xml(自定义名称) 系统核心配置文件
mapper.xml (自定义名称)SQL映射文件
Mybatis的核心接口和类
SqlSessionFactoryBuilder
SqlSessionFactory
SqlSession
以上包的import路径都是org.apache.ibatis.xx
环境的搭建:
1、下载 Mybatis jar包并导入项目,这里使用的是mybatis 3.2.x版本,数据库是mysql 5.5
2、编写核心配置文件:
新建一个xml文件,命名为mybatis-config.xml,配置文件头内容如下:
<?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标签,并在该标签内做其他的各项配置
<configuration>
<!-- 引入 database.properties 文件 -->
<!-- 这里${}中的名称要跟你database.properties中的名称一致 -->
<properties resource="database.properties">
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="user" value="${user}" />
<property name="password" value="${password}" />
</properties>
<settings>
<!-- 配置mybatis的log实现为LOG4J -->
<setting name="logImpl" value="LOG4J" />
<!--自动匹配配置,FULL表示全部自动匹配映射-->
<setting name="autoMappingBehavior" value="FULL" />
</settings>
<typeAliases>
<!--别名设置,通过这项设置,在需要使用完整限定名的地方,name值的部分就可以省略不写了-->
<package name="cn.smbms.pojo" />
</typeAliases>
<!--环境设置,复数名词,可以有多个环境,每个环境的id不同用以区分唯一,但需要指定一个默认环境-->
<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="${user}" />
<property name="password" value="${password}" />
</dataSource>
</environment>
<!--这是另一个环境-->
<environment id="product">
<!--配置事务管理,采用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="${user}" />
<property name="password" value="${password}" />
</dataSource>
</environment>
</environments>
<!-- 将mapper映射文件加入到核心配置文件中,每一个接口都需要配置一个mapper.xml -->
<mappers>
<!--有resource和file两种引入方式,这里用resource-->
<mapper resource="cn/smbms/dao/UserMapper.xml" />
</mappers>
</configuration>
3.生成mybatis对象,这里我们可以通过创建一个单例的工具类,快速生成mybatis对象:
package cn.smbms.utils;
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 java.io.IOException;
import java.io.InputStream;
public class MyBatisUtils {
//创建SqlSessionFactory 对象
private static SqlSessionFactory factory;
//静态代码块,在类加载的时候就执行,并且只执行一次
static {
//指定mybatis核心配置文件
String resource = "mybatis-config.xml";
//创建输入流
InputStream is;
try {
is = Resources.getResourceAsStream(resource);
factory = new SqlSessionFactoryBuilder().build(is);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//创建SqlSession
public static SqlSession getSQLSession() {
return factory.openSession(false);//true:关闭事务控制 ,false:开启事务控制
}
//关闭SqlSession
public static void closeSqlSession(SqlSession sqlSession) {
if (sqlSession != null) {
sqlSession.close();
}
}
}
说明:
SqlSessionFactoryBuilder
用过即丢,其生命周期只存在于方法体内
作用:可重用其来创建多个SqlSessionFactory实例,并提供多个.build()方法的重载,分别是 InputStream字节流、Reader字符流、Configuration类
SqlSessionFactory
SqlSessionFactory是每个Mybatis应用的核心
作用:创建SqlSession实例
SqlSession
包含了执行SQL所需的所有方法,对应一次数据库会话(request),会话结束必须关闭
是线程级别,不能共享
sqlsession可以执行多次sql语句,但只要关闭了,就需要再次创建
作用:执行增删改查
到这里,mybatis核心配置文件就简单的完成了,可以通过工具类MyBatisUtils的.getSQLSession()快速生成一个sqlsession对象
Mybatis框架的使用之二传送门:
https://blog.csdn.net/wangduanqs/article/details/85015566