1 mybatis 連接池
- 連接池就是用於存儲連接的一個容器
- 容器就是一個集合對象,該集合必須是線程安全的,不能兩個線程拿到同一個連接
- 該集合還必須實現隊列的特性:先進先出
mybatis 連接池提供了 3 種方式配置
- 配置的位置: 主配置文件
SqlMapConfig.xml
中dataSource
標籤, type 屬性就是表示採用何種連接池方式
type 屬性取值:
POOLED
: 採用傳統javax.sql.DataSource
規範中的連接池,mybatis 有針對規範的實現UNPOOLED
: 採用傳統的連接方法,雖然也實現了javax.sql.DataSource
接口,但是並沒有使用池的思想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>