Mybatis入门
概述
一个半自动化的ORM框架,他是作用于DAO层,拥有强大的动态sql的能力,小巧灵活,简单易学
框架
ORM
编写程序的时候,以面向对象的方式处理数据 保存数据的时候,却以关系型数据库的方式存储
ORM解决方案
在持久化对象上执行基本的增、删、改、查操作 对持久化对象提供一种查询语言或者API 对象关系映射工具 提供与事务对象交互、执行检查、延迟加载以及其他优化功能
开发步骤
- 下载mybatis-3.2.2.jar包并导入工程
- 编写MyBatis核心配置文件(configuration.xml)
- 创建实体类-POJO
- DAO层-SQL映射文件(mapper.xml)
- 创建测试类 读取核心配置文件mybatis-config.xml 创建SqlSessionFactory对象,读取配置文件 创建SqlSession对象 调用mapper文件进行数据操作
核心对象
SqlSessionFactoryBuilder
用过即丢,其生命周期只存在于方法体内 可重用其来创建多个 SqlSessionFactory 实例 负责构建SqlSessionFactory,并提供多个build方法的重载
代码语言:javascript复制//读取XML文件构造方式:
String resource = "mybatis-config.xml";
InputStream is = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
代码语言:javascript复制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实例
代码语言:javascript复制SqlSession session = sqlSessionFactory.openSession(boolean autoCommit);
作用域:Application 生命周期与应用的生命周期相同 单例 存在于整个应用运行时,并且同时只存在一个对象实例
SqlSession
包含了执行SQL所需的所有方法 对应一次数据库会话,会话结束必须关闭 线程级别,不能共享
代码语言:javascript复制SqlSession session = sqlSessionFactory.openSession();
try {
// do work
} finally {
session.close();
}
关闭SqlSession非常重要,必须要确保在finally方法体中正常关闭
整体创建方式
代码语言:javascript复制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),实现动态配置
代码语言:javascript复制<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,实现动态配置
代码语言:javascript复制<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类名
代码语言:javascript复制<typeAliases>
<typeAlias alias="User" type="cn.smbms.pojo.User"/>
</typeAliases>
代码语言:javascript复制<typeAliases>
<package name ="cn.smbms.pojo" />
</typeAliases>
typeHandlers 类型处理器
objectFactory 对象工厂
plugins 插件
environments 环境
表示配置MyBatis的多套运行环境,将SQL映射到多个不同的数据库上 子元素节点:environment,但是必须指定其中一个为默认运行环境(通过default指定)
代码语言:javascript复制<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 事务管理器
代码语言:javascript复制<transactionManager type="[ JDBC | MANAGED ]" />
dataSource 数据源
dataSource dataSource元素使用基本的JDBC数据源接口来配置JDBC连接对象的资源 有三种内建的数据源类型
代码语言:javascript复制<dataSource type=" [UNPOOLED | POOLED | JNDI]" />
代码语言:javascript复制<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映射文件
方式一
使用类资源路径获取资源
代码语言:javascript复制<!-- 将mapper映射文件加入到系统核心配置文件中 -->
<mappers>
<mapper resource="cn/smbms/dao/user/UserMapper.xml"/>
</mappers>
方式二
使用URL获取资源
代码语言:javascript复制<mappers>
<mapper url="file:///E:/sqlmappers/UserMapper.xml"/>
<mapper url="file:///E:/sqlmappers/ProviderMapper.xml"/>
</mappers>
SQL映射文件
下章节见