事务

(1) 默认需要手动提交事务

Mybatis 框架是对JDBC 的封装,所以 Mybatis 框架的事务控制方式,本身也是用JDBC 的 Connection 对象的commit(), rollback() .

Connection 对象的setAutoCommit()方法来设置事务提交方式的。自动提交和手工提交、

​< transactionManager type="JDBC"/>​

该标签用于指定 MyBatis 所使用的事务管理器。MyBatis 支持两种事务管理器类型:

JDBC 与MANAGED。

JDBC:使用JDBC 的事务管理机制。即,通过Connection 的 commit() 方法提交,通过rollback()方法回滚。但默认情况下,MyBatis 将自动提交功能关闭了,改为了手动提交。即程序中需要显式的对事务进行提交或回滚。从日志的输出信息中可以看到。

深入mybatis配置文件之事务_事务管理ANAGED:由容器来管理事务的整个生命周期(如 Spring 容器)。

(2) 自动提交事务

设置自动提交的方式,factory 的openSession() 分为有参数和无参数的。

深入mybatis配置文件之事务_xml_02

有参数为true,使用自动提交,可以修改MyBatisUtil 的getSqlSession()方法。

​session = factory.openSession(true);​

再执行insert 操作,无需执行session.commit(),事务是自动提交的

使用数据库属性配置文件

为了方便对数据库连接的管理,DB 连接四要素数据一般都是存放在一个专门的属性文件中的。MyBatis 主配置文件需要从这个属性文件中读取这些数据。

步骤:

(1) 在 classpath 路径下,创建 properties 文件

在resources 目录创建jdbc.properties 文件,文件名称自定义。

深入mybatis配置文件之事务_事务管理_03

(2) 使用 properties 标签

修改主配置文件,文件开始位置加入:

深入mybatis配置文件之事务_事务管理_04

(3) 使用 key 指定值

深入mybatis配置文件之事务_xml_05

typeAliases(类型别名)

Mybatis 支持默认别名,我们也可以采用自定义别名方式来开发,主要使用在

< select resultType=” 别 名 ”> 

mybatis.xml 主配置文件定义别名:

深入mybatis配置文件之事务_配置文件_06

mapper.xml 文件,使用别名表示类型

深入mybatis配置文件之事务_事务管理_07

mappers(映射器)

(1) <mapper resource=" " />

使用相对于类路径的资源,从classpath 路径查找文件

例如:

(2) <package name=""/>

指定包下的所有 Dao 接口

如:

注意:此种方法要求Dao 接口名称和mapper 映射文件名称相同,且在同一个目录中。