MyBatis(14)- Mybatis 連接池和事務

1 mybatis 連接池

  • 連接池就是用於存儲連接的一個容器
  • 容器就是一個集合對象,該集合必須是線程安全的,不能兩個線程拿到同一個連接
  • 該集合還必須實現隊列的特性:先進先出

mybatis 連接池提供了 3 種方式配置

  • 配置的位置: 主配置文件 SqlMapConfig.xmldataSource 標籤, type 屬性就是表示採用何種連接池方式

type 屬性取值:

  1. POOLED : 採用傳統 javax.sql.DataSource 規範中的連接池,mybatis 有針對規範的實現
  2. UNPOOLED : 採用傳統的連接方法,雖然也實現了 javax.sql.DataSource 接口,但是並沒有使用池的思想
  3. JNDI : 採用服務器提供的 JNDI 技術實現,獲取 DataSource 對象,不同的服務器拿到的DataSource 不一樣。注意:如果不是 web 或者 maven 的war 工程,是不能使用的。

2 配置連接池

<?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">
<!-- mybatis 的主配置文件-->
<configuration>

    <properties resource="jdbc.properties"></properties>
    
    <!--配置別名,配置 domain 類中的別名
        配置了別名後,就不在區分大小寫
    -->
    <typeAliases>
        <!--該包下所有的實體類都被註冊別名,類名就是別名,不在區分大小寫-->
        <package name="com.tzb.domain"/>
    </typeAliases>

    <!--配置環境-->
    <environments default="mysql">
        <environment id="mysql">
            <!--配置事務類型-->
            <transactionManager type="JDBC"></transactionManager>

            <!--配置數據源(連接池)-->
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>

    <!--指定dao接口所在的包,不需要再寫 mapper 以及resource或者 class-->
    <mappers>
        <package name="com.tzb.dao"/>
    </mappers>

</configuration>

3 事務

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章