概要
通篇了解,后期与spring集成
- 配置连接数据库的四个元素
- 注册实体类的权限定性类名的别名
- 配置MyBatis运行环境,即数据源与事务管理器
- 注册映射文件
一、properties
1、概要
主要是用来定义配置外在化,比如数据库的连接属性等。这些属性都是可外部配置且可动态替换的,既可以在典型的Java属性文件中配置,亦可以通过properties元素的子元素来传递
将数据库连接参数单独配置在db.properties中,放在类路径下。这样只需要在config.xml中加载db.properties的属性值。这样在config.xml中就不需要对数据库连接参数硬编码。
将数据库连接参数只配置在db.properties中,方便对参数进行统一管理,其它xml可以引用该db.properties
2、示例代码
- 定义外部的db.properties
driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mybatis username=root password=root //然后在mybatis-config.xml引用 <properties resource="config/db.properties"/>
- 也可直接在properties元素中配置(不推荐)
<properties> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/> <property name="username" value="root"/> <property name="password" value="root"/> </properties>
二、设置(settings)
1、概要
修改MyBatis在运行时的行为方式。如果不熟悉配置建议使用默认配置
settings 的配置项很多,但是真正用到的不会太多,常用的配置缓存的 cacheEnabled,级联的 lazyLoadingEnabled 和 aggressiveLazy Loading,驼峰命名规则mapUnderscoreToCamelCase,执行器类型的 defaultExecutorType 等。
2、常用的设置
设置名 | 描述 | 有效值 | 默认值 |
---|---|---|---|
cacheEnabled | 全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存。 | true | false | true |
lazyLoadingEnabled | 延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 fetchType 属性来覆盖该项的开关状态。 |
true | false | false |
aggressiveLazyLoading | 当开启时,任何方法的调用都会加载该对象的所有属性。 否则,每个属性会按需加载(参考 lazyLoadTriggerMethods )。 |
true | false | false (在 3.4.1 及之前的版本默认值为 true) |
multipleResultSetsEnabled | 是否允许单一语句返回多结果集(需要驱动支持)。 | true | false | true |
useColumnLabel | 使用列标签代替列名。不同的驱动在这方面会有不同的表现,具体可参考相关驱动文档或通过测试这两种不同的模式来观察所用驱动的结果。 | true | false | true |
useGeneratedKeys | 允许 JDBC 支持自动生成主键,需要驱动支持。 如果设置为 true 则这个设置强制使用自动生成主键,尽管一些驱动不能支持但仍可正常工作(比如 Derby)。 | true | false | False |
mapUnderscoreToCamelCase | 是否开启自动驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN 到经典 Java 属性名 aColumn 的类似映射。 | true | false | False |
jdbcTypeForNull | 当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。 某些驱动需要指定列的 JDBC 类型,多数情况直接用一般类型即可,比如 NULL、VARCHAR 或 OTHER。 | JdbcType 常量,常用值:NULL, VARCHAR 或 OTHER。 | OTHER |
defaultEnumTypeHandler | 指定 Enum 使用的默认 TypeHandler 。(新增于 3.4.5) |
一个类型别名或完全限定类名。 | org.apache.ibatis.type.EnumTypeHandler |
returnInstanceForEmptyRow | 当返回行的所有列都是空时,MyBatis默认返回 null 。 当开启这个设置时,MyBatis会返回一个空实例。 请注意,它也适用于嵌套的结果集 (如集合或关联)。(新增于 3.4.2) |
true | false | false |
二、配置环境(environments)
1、概要
配置环境主要指的是配置SqlSessionFactory的初始化参数,比如:数据库的事物管理机制还有连接数据的一些必要参数
MyBatis 可以配置成适应多种环境,这种机制有助于将 SQL 映射应用于多种数据库之中, 现实情况下有多种理由需要这么做。例如,开发、测试和生产环境需要有不同的配置;或者共享相同 Schema 的多个生产数据库, 想使用相同的 SQL 映射。许多类似的用例。
注:尽管可以配置多个环境,每个 SqlSessionFactory 实例只能选择其一
2、environment
1、说明
如果你想连接两个数据库,就需要创建两个 SqlSessionFactory 实例,每个数据库对应一个。而如果是三个数据库,就需要三个实例,依此类推,
每个数据库环境对应一个 SqlSessionFactory 实例
2.2、示例代码
- java代码
//指定配置文件 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, environment); SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader, environment,properties); //使用默认的配置文件加载 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader); SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader,properties);
- xml配置
<environments default="dev"> <environment id="dev"> </environment> <environment id="test"> </environment> <environment id="product"> </environment> </environments>
- 关键点
默认的环境 ID(environments元素的属性 default=”dev”)
每个 environment 元素定义的环境 ID(environment元素的属性id=”dev”, id="product")
3、事务管理器(transactionManager)
3.1、概要
在 MyBatis 中有两种类型的事务管理器 主要是通过type属性将配置
- type="JDBC"
这个配置就是直接使用了 JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域 - type="MANAGED"
这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置为 false 来阻止它默认的关闭行为
3.2、示例代码
- 示例一(JDBC)
<environments default="dev"> <environment id="dev"> <transactionManager type="JDBC"> <property name="..." value="..."/> </transactionManager> </environment> </environments>
- 示例二(MANAGED)
<transactionManager type="MANAGED"> <property name="closeConnection" value="false"/> </transactionManager>
4、数据源(dataSource)
4.1、概要
配置MyBatis使用的数据源类型与数据库连接基本属性
- UNPOOLED
- POOLED
- JNDI
4.2、UNPOOLED
- 说明
UNPOOLED:不使用连接池。即每次请求,都会为其创建一个DB连接,使用完毕后,会马上将此连接关闭 - 属性介绍
属性 说明 driver 这是 JDBC 驱动的 Java 类的完全限定名(并不是JDBC驱动中可能包含的数据源类 url 这是数据库的 JDBC URL 地址。 username 登录数据库的用户名。 password 登录数据库的密码 defaultTransactionIsolationLevel 默认的连接事务隔离级别 - 示例代码
<environments default="dev"> <environment id="dev"> <transactionManager type="JDBC"/> <dataSource type="UNPOOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <defaultTransactionIsolationLevel name> </dataSource> </environment> </environments>
4.3、POOLED
- 说明
使用数据库连接池来维护连接 - 属性介绍
属性 说明 poolMaximumActiveConnections 在任意时间可以存在的活动(也就是正在使用)连接数量,默认值:10 poolMaximumIdleConnections 任意时间可能存在的空闲连接数 poolMaximumCheckoutTime 在被强制返回之前,池中连接被检出(checked out)时间,默认值:20000 毫秒(即 20 秒) poolTimeToWait 这是一个底层设置,如果获取连接花费的相当长的时间,它会给连接池打印状态日志并重新尝试获取一个连接(避免在误配置的情况下一直安静的失败),默认值:20000 毫秒(即 20 秒) poolMaximumLocalBadConnectionTolerance 这是一个关于坏连接容忍度的底层设置, 作用于每一个尝试从缓存池获取连接的线程. 如果这个线程获取到的是一个坏的连接,那么这个数据源允许这 个线程尝试重新获取一个新的连接,但是这个重新尝试的次数不应该超过 poolMaximumIdleConnections
与poolMaximumLocalBadConnectionTolerance
之和。 默认值:3poolPingQuery 发送到数据库的侦测查询,用来检验连接是否处在正常工作秩序中并准备接受请求。默认是“NO PING QUERY SET”,这会导致多数数据库驱动失败时带有一个恰当的错误消息 poolPingEnabled 是否启用侦测查询。若开启,也必须使用一个可执行的 SQL 语句设置 poolPingQuery 属性(最好是一个非常快的 SQL),默认值:false poolPingConnectionsNotUsedFor 配置 poolPingQuery 的使用频度。这可以被设置成匹配具体的数据库连接超时时间,来避免不必要的侦测,默认值:0(即所有连接每一时刻都被侦测 — 当然仅当 poolPingEnabled 为 true 时适用 - 示例代码
<dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource>
//通过properties配置 <dataSource type="POOLED"> <property name="driver" value="${dirver}"/> <property name="url" value="${url}"/> <property name="username" value="${user}"/> <property name="password" value="${password}"/> </dataSource>
4.4、JDNI(了解)
- 说明
为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用 - 属性介绍
属性 说明 initial_context 这个属性用来在 InitialContext 中寻找上下文(即,initialContext.lookup(initial_context))。这是个可选属性,如果忽略,那么 data_source 属性将会直接从 InitialContext 中寻找。 data_source 这是引用数据源实例位置的上下文的路径。提供了 initial_context 配置时会在其返回的上下文中进行查找,没有提供时则直接在 InitialContext 中查找。 - 示例代码
1、环境配置
2、tomcatconf目录下配置context.xml<environment id="dev"> <dataSource type="JNDI"> <property name="data_source" value="java:comp/env/jndi/mybatis"/> </dataSource> </environment>
<Resource name="jndi/mybatis" <!--这里就是上文自己定义的目录--> auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/mybatis" username="root" password="root" poolMaximumActiveConnections="20" poolMaximumIdleConnections="10" poolMaximumCheckoutTime="10000"/>
4.5、第三方数据源(了解)
- 概要
Mybaits也可以通过需要实现接口 org.apache.ibatis.datasource.DataSourceFactory来配置第三方的数据源
在开发中ssm整合的时候配置在去使用或者配合SpringBoot - 示例代码
1、java代码
2、环境配置public class C3P0DataSourceFactory extends UnpooledDataSourceFactory { public C3P0DataSourceFactory() { this.dataSource = new ComboPooledDataSource(); } }
<dataSource type="com.werner.config.C3P0DataSourceFactory"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource>
三、映射器(Mapper)
1、概要
定义SQL映射语句。首先需要告诉MyBatis到哪里去找到这些语句。Java在自动查找这方面没有提供一个很好的方法,所以最佳的方式是告诉MyBatis到哪里去找映射文件。可以使用相对于类路径的资源引用、或完全限定资源定位符(包括file:///的URL),或类名和包名等等
2、配置方式
1、<mapper resource="">
- 说明
resource指向的是相对于类路径下的目录 - 示例代码
<mapper resource="mapper/User.xml" />
-
结构图
2、<mapper class="" />
- 说明
使用mapper接口类路径 - 示例代码
<mapper class="com.werner.mybatis.mapper.UserMapper"/>
-
工程结构
- 注意
- 映射文件名要与dao接口名相同
- 映射文件要与接口在同一包中
- 映射文件中
<mapper/>
的namespace属性值为dao接口的全类名
3、<package name="">
- 说明
注册指定包下的所有mapper接口 - 示例代码
<package name="com.werner.mybatis.mapper"/>
- 注意
- dao使用mapper动态代理实现
- 映射文件名要与dao接口名相同
- 映射文件要与接口在同一包中
- 映射文件中<mapper/>的namespace属性值为dao接口的全类名
4、<mapper url="" />
- 说明
使用完全限定路径,可以将映射文件放在本地或网络的任意位置,通过url地址即可直接访问。当通常映射文件是存放在当前应用中的,所以该方式不常用 - 示例代码
<mapper url="file:///D:\workspace\mybatis\config\mapper\User.xml" />
四、TypeAliase(类型别名)
1、概要
指定实体类权限定性类名的别名,通过这种方式设置别名在以后的操作是如果用到了某个javabean的完全限定名的时候我们就可以使用alias设置的值来代替,从而简化了编程
2、配置方式
1、xml配置方式
1、package方式
- 说明
一般使用<package/>
方式,这样做的好处是会将该包中的所有实体类的简单类名指定为别名 - 示例代码
<!--配置别名--> <typeAliases> <package name="com.werner.mybatis.entity"/> </typeAliases>
2、通过typealias指定
- 说明
该方式的好处是,可以指定别名为简单类名以外的其他名称。当然,弊端是,必须逐个指定,比较繁琐。 - 属性
- type:权限定性类名
- alias:别名
- 示例代码
<!-- 注册类的别名 --> <typeAliases> <typeAlias type="com.werner.mybatis.entity.User" alias="User"/> </typeAliases>
3、注解配置方式
- 示例代码
import org.apache.ibatis.type.Alias; @Alias(value = "User") public class User { private int uid; private String name; }
3、内置的类型别名
别名 | 映射的类型 |
---|---|
_byte | byte |
_long | long |
_short | short |
_int | int |
_integer | int |
_double | double |
_float | float |
_boolean | boolean |
string | String |
byte | Byte |
long | Long |
short | Short |
int | Integer |
integer | Integer |
double | Double |
float | Float |
boolean | Boolean |
date | Date |
decimal | BigDecimal |
bigdecimal | BigDecimal |