mybatis environments

environments 运行环境

在mybatis中运行环境主要是配置了数据库信息,他可以配置多个数据库。下面它有分为transactinManager 事务管理器 和dataSource 数据源 配置项。在实际工作中通常是采用Spring对这两个配置项进行管理。

transactionManager 事务管理器

在mybatis中,transactionManager 提供了两个实现类。但是他需要实现Transaction接口。

public interface Transaction {

  /**
   * Retrieve inner database connection
   * @return DataBase connection
   * @throws SQLException
   */
  Connection getConnection() throws SQLException;

  /**
   * Commit inner database connection.
   * @throws SQLException
   */
  void commit() throws SQLException;

  /**
   * Rollback inner database connection.
   * @throws SQLException
   */
  void rollback() throws SQLException;

  /**
   * Close inner database connection.
   * @throws SQLException
   */
  void close() throws SQLException;

  /**
   * Get transaction timeout if set
   * @throws SQLException
   */
  Integer getTimeout() throws SQLException;

}

从方法可知,他的主要方法就是提交,回滚和关闭数据库的事务。他的实现类为JdbctransactionManager 和 ManagerTransaction。由于他们都是采用工厂模式来生成对象,所以他们还对应两个工厂类JdbctransactionManagerFactory和ManagerTransactionFactory。
JdbctransactionManager对事务的处理采用JDBC的方式对数据库的提交和回滚进行操作
ManagerTransaction 它的提交和回滚不用任何操作,而是将事物交给容器处理。默认情况下他会关闭数据库连接,,因此要将closeConnection的属性设置为false。

environment 数据源环境

environment的主要作用是配置数据库,其中有三种配置数据源的方式,PooledDataSource,
UnpooledDataSource 和 JndiDataSource, 分别对应三个工厂方法来生产这三个类的对象。

UnpooledDataSource

采用非池数据库管理方式。它有以下配置项
- driver 数据库驱动
- url 连接数据库的URL
- username 数据库用户名
- password 密码

- defaultTransactionIsolationLevel 默认的链接事务隔离级别

PooledDataSource

数据源POOLED利用 池 的概念把JDBC的connection集中管理。也就是数据库连接池。
除了UnpooledDataSource还有以下可配置项
- poolMaxmumActiveConnections 是任意时间都存在的活动连接数量,默认为10
- poolMaxmumIdleConnections 任意时间可能存在的空闲连接数
- poolMaxmumCheckoutTime 被强制返回之前,池中链接被检查出的时间。默认20s
- poolTimeToWait 如果获取连接时间较长则打印日志并尝试获取新连接
- poolPingQuery 为发送数据库侦测查询,检验数据库是否处于正常的工作状态,默认为
NO PING QUERY SET 这回导致多数数据库失败时带有一个恰当是错误提示。
- poolPingEnabled 为是否启用数据库侦测查询。若开启也必须使用一个可执行的Sql语句设置poolPingQuery属性。默认为false
- poolPingConnectionsNotUsedFor 配置poolPingQuery的使用频度。默认值为 0 ,也就是所有链接每时都会侦测,仅当poolPingEnabled为true生效。

JNDI

EJB等应用服务器使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值