0%

4.配置解析

4.1核心配置文件

在xml中所有的标签都可以规定其顺序

  • mybatis-config.xml

  • MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。

  • configuration(配置)
    properties(属性)
    settings(设置)
    typeAliases(类型别名)
    typeHandlers(类型处理器)
    objectFactory(对象工厂)
    plugins(插件)
    environments(环境配置)
    environment(环境变量)
    transactionManager(事务管理器)
    dataSource(数据源)
    databaseIdProvider(数据库厂商标识)
    mappers(映射器)
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22



    ### 4.2环境配置(environments)

    **尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。**

    Mybatis默认的事务管理器是JDBC,连接池POOLED

    ### 4.3属性(properties)

    我们可以通过properties属性实现引用配置文件

    这些属性都是可外部配置且可动态替换的,既可以在典型的 Java 属性文件中配置,亦可通过 properties 元素的子元素来传递【db.properties】

    编写一个配置文件

    ```properties
    dirver=com.mysql.jdbc.Driver
    url=jdbc:mysql://localhost:3306/mybatis_test
    username=root
    password=liwenjie

在核心配置文件中引入

1
2
3
4
<!--引入外部配置文件-->
<properties resource="db.properties">

</properties>
  • 可以直接引用外部文件
  • 也可以在其中增加一些属性配置
  • 如果外部和内部配置有相同属性,优先外部配置文件

4.4类型别名(typeAliases)

  • 类型别名是为 Java 类型设置一个短的名字。 它只和 XML 配置有关
  • 存在的意义仅在于用来减少类完全限定名的冗余。
1
2
3
4
<!--给实体类起别名-->
<typeAliases>
<typeAlias type="pojo.User" alias="User"></typeAlias>
</typeAliases>

也可以指定一个包名,MyBatis 会在包名下面搜索需要的 Java Bean,比如:

扫描实体类的包,他的默认别名就是这个类的类名首字母小写。

1
2
3
<typeAliases>
<package name="pojo"/>
</typeAliases>

在实体类少的时候使用第一种方式

如果实体类较多的时候可以考虑第二种。

第一种的DIY性比较好。

第三种就是使用注解来建立别名

1
2
3
4
5
6
@Alias("hello")
public class User {
private int id;
private String name;
private String pwd;
``
1
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

### 4.5 设置(settings)

| cacheEnabled | 全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存。 | true |
| :----------------------- | ------------------------------------------------------------ | ----- |
| lazyLoadingEnabled | 延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 `fetchType` 属性来覆盖该项的开关状态。 | false |
| mapUnderscoreToCamelCase | 是否开启自动驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN 到经典 Java 属性名 aColumn 的类似映射。 | False |

​```xml
一个配置完整的 settings 元素的示例如下:
<settings>
<setting name="cacheEnabled" value="true"/>
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="multipleResultSetsEnabled" value="true"/>
<setting name="useColumnLabel" value="true"/>
<setting name="useGeneratedKeys" value="false"/>
<setting name="autoMappingBehavior" value="PARTIAL"/>
<setting name="autoMappingUnknownColumnBehavior" value="WARNING"/>
<setting name="defaultExecutorType" value="SIMPLE"/>
<setting name="defaultStatementTimeout" value="25"/>
<setting name="defaultFetchSize" value="100"/>
<setting name="safeRowBoundsEnabled" value="false"/>
<setting name="mapUnderscoreToCamelCase" value="false"/>
<setting name="localCacheScope" value="SESSION"/>
<setting name="jdbcTypeForNull" value="OTHER"/>
<setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString"/>
</settings>

4.6映射器(mappers)

既然 MyBatis 的行为已经由上述元素配置完了,我们现在就要定义 SQL 映射语句了。 但是首先我们需要告诉 MyBatis 到哪里去找到这些语句。 Java 在自动查找这方面没有提供一个很好的方法,所以最佳的方式是告诉 MyBatis 到哪里去找映射文件。 你可以使用相对于类路径的资源引用, 或完全限定资源定位符(包括 file:/// 的 URL),或类名和包名等。

1
2
3
4
5
6
<!-- 使用相对于类路径的资源引用 -->
<mappers>
<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
<mapper resource="org/mybatis/builder/BlogMapper.xml"/>
<mapper resource="org/mybatis/builder/PostMapper.xml"/>
</mappers>

只看着一个吧,其他的反正也记不住。。。。

4.7作用域(Scope)和生命周期

SqlSessionFactoryBuilder:

  • 一旦创建了 SqlSessionFactory,就不再需要它了
  • 局部变量

SqlSessionFactory:

  • 说白了就是可以想象为数据库连接池
  • 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例
  • 因此 SqlSessionFactory 的最佳作用域是应用作用域,全局
  • 最简单的就是使用单例模式或者静态单例模式。

SqlSession

  • 连接到连接池的一个请求
  • 开启–>关闭
  • 线程不安全,不能被共享
  • 用完赶紧关闭,否则资源被占用