Mybatis框架的使用之一(环境搭建)

Mybatis是当今比较流行的、开源的数据持久化层(DAO)框架,作为SSM框架之一,它可以在实体类与SQL语句之间建立映射关系。

主要有以下优点:

  1. 与JDBC相比,减少了50%以上代码量
  2. 是最简单的持久化框架、小巧简单易学
  3. SQL代码从程序代码中彻底分离,可重用
  4. 提供XML标签,支持编写动态SQL
  5. 提供映射标签,支持对象与数据库的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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值