本文最后更新于 2023-07-23,文章内容可能已经过时,请注意内容的辨别。

Mybatis入门

概述

一个半自动化的ORM框架,他是作用于DAO层,拥有强大的动态sql的能力,小巧灵活,简单易学

框架

ORM

编写程序的时候,以面向对象的方式处理数据 保存数据的时候,却以关系型数据库的方式存储

ORM解决方案

在持久化对象上执行基本的增、删、改、查操作 对持久化对象提供一种查询语言或者API 对象关系映射工具 提供与事务对象交互、执行检查、延迟加载以及其他优化功能

开发步骤

  1. 下载mybatis-3.2.2.jar包并导入工程

  2. 编写MyBatis核心配置文件(configuration.xml)

  3. 创建实体类-POJO

  4. DAO层-SQL映射文件(mapper.xml)

  5. 创建测试类 读取核心配置文件mybatis-config.xml 创建SqlSessionFactory对象,读取配置文件 创建SqlSession对象 调用mapper文件进行数据操作

核心对象

SqlSessionFactoryBuilder

用过即丢,其生命周期只存在于方法体内 可重用其来创建多个 SqlSessionFactory 实例 负责构建SqlSessionFactory,并提供多个build方法的重载

//读取XML文件构造方式:
String resource = "mybatis-config.xml";   
InputStream is = Resources.getResourceAsStream(resource);   
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
​
build(InputStream inputStream, String environment, Properties properties) 
build(Reader reader, String environment, Properties properties)
build(Configuration config)
​
配置信息以三种形式提供给SqlSessionFactory的build方法:
InputStream (字节流)、Reader(字符流)、Configuration(类)
​

SqlSessionFactory

SqlSessionFactory是每个MyBatis应用的核心 作用:创建SqlSession实例

SqlSession session = sqlSessionFactory.openSession(boolean autoCommit);

作用域:Application 生命周期与应用的生命周期相同 单例 存在于整个应用运行时,并且同时只存在一个对象实例

SqlSession

包含了执行SQL所需的所有方法 对应一次数据库会话,会话结束必须关闭 线程级别,不能共享

SqlSession session = sqlSessionFactory.openSession();
try {
      // do work
} finally {
     session.close();
}

关闭SqlSession非常重要,必须要确保在finally方法体中正常关闭

整体创建方式

String resource = "mybatis-config.xml";   
InputStream  is = Resources.getResourceAsStream(resource);   
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is) ;
SqlSession sqlSession = factory.openSession();
SqlSession的两种使用方式

通过SqlSession实例直接运行映射的SQL语句 基于Mapper接口方式操作数据

系统核心配置文件

configuration 配置

properties 可以配置在Java 属性配置文件中
  • 通过外部指定的方式(database.properties),实现动态配置

    <properties resource="database.properties"/>      
    ......
    <dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${user}"/>
        <property name="password" value="${password}"/>
    </dataSource>
    ​

  • 直接配置为xml,实现动态配置

    <properties>
            <property name="driver" value="com.mysql.jdbc.Driver"/>
            <property name="url" value="jdbc:mysql://127.0.0.1:3306/smbms"/>
            <property name="user" value="root"/>
            <property name="password" value="root"/>
    </properties>
    ......
    <dataSource type="POOLED">
            <property name="driver" value="${driver}"/>
            <property name="url" value="${url}"/>
            <property name="username" value="${user}"/>
            <property name="password" value="${password}"/>
    </dataSource>
    ​

    resource属性值的优先级高于property子节点配置的值

settings 修改 MyBatis 在运行时的行为方式

用来修改MyBatis运行时的行为方式 主要是MyBatis的一些全局配置属性的设置

设置项

描述

允许值

默认值

cacheEnabled

对在此配置文件下的所有cache进行全局性开/关设置

true | false

true

lazyLoadingEnabled

全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载

true | false

true

autoMappingBehavior

MyBatis对于resultMap自动映射匹配级别

NONE |PARTIAL |FULL

PARTIAL

typeAliases 为 Java 类型命名一个别名(简称)

类型别名 仅仅只关联XML配置,简写冗长的Java类名

<typeAliases>
    <typeAlias alias="User" type="cn.smbms.pojo.User"/>
</typeAliases>
​
<typeAliases>
	<package name ="cn.smbms.pojo" />
</typeAliases>
typeHandlers 类型处理器
objectFactory 对象工厂
plugins 插件
environments 环境

表示配置MyBatis的多套运行环境,将SQL映射到多个不同的数据库上 子元素节点:environment,但是必须指定其中一个为默认运行环境(通过default指定)

<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<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="test">
……
</environment>
</environments>

environment 环境变量
transactionManager 事务管理器
<transactionManager type="[ JDBC | MANAGED ]" />
dataSource 数据源

dataSource dataSource元素使用基本的JDBC数据源接口来配置JDBC连接对象的资源 有三种内建的数据源类型

<dataSource type=" [UNPOOLED | POOLED | JNDI]" />
<dataSource type="POOLED">
	<property name="driver" value="${driver}"/>
 	<property name="url" value="${url}"/>
	<property name="username" value="${user}"/>
	<property name="password" value="${password}"/>
</dataSource>

mappers 映射器

映射器,定义SQL映射语句 须在配置中引用mapper映射文件

方式一

使用类资源路径获取资源

<!-- 将mapper映射文件加入到系统核心配置文件中 -->
<mappers>
	<mapper  resource="cn/smbms/dao/user/UserMapper.xml"/>
</mappers>
方式二

使用URL获取资源

<mappers>
		<mapper url="file:///E:/sqlmappers/UserMapper.xml"/>
		<mapper url="file:///E:/sqlmappers/ProviderMapper.xml"/>
</mappers>

SQL映射文件

下章节见