[Mybatis]配置解析相关(重点)

88 阅读3分钟

一.配置之属性优化

1核心配置文件

2.环境配置(environments)

MyBatis 可以配置成适应多种环境 不过要记住:尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。

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

  • 编写mybatis-config.xml配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<!--configuration核心配置文件-->
<configuration>
    <!--default 切换环境-->
    <environments default="development">
        <!--开发环境-->
        <environment id="development">
            <!--事务管理器 默认事务处理器JDBC-->
            <transactionManager type="JDBC"/>
            <!--数据源 默认POOLED / UNPOOLED-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/sqlstudy?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
        <!--测试环境-->
        <environment id="test">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/sqlstudy?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="mybatisstudy/dao/UserMapper.xml"/>
    </mappers>
</configuration>

3.属性(properties)

可以通过properties属性来引用配置文件

这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties 元素的子元素中设置。

  • 编写数据库配置文件db.properties
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/sqlstudy?useSSL=true&useUnicode=true&characterEncoding=UTF-8
username=root
password=123456

注意点 配置文件的引用

image.png

  • 在核心配置文件中映入
    • 核心代码
 <!--映入外部配置文件-->
    <properties resource="db.properties">
        <!--可以全写在db.properties里  也可以两边搭配混合都能实现效果,如果存在 优先使用外部配置文件-->
<!--        <property name="username" value="root"/>-->
<!--        <property name="password" value="123456"/>-->
    </properties>
    • 完整代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<!--configuration核心配置文件-->
<configuration>
    <!--映入外部配置文件-->
    <properties resource="db.properties">
        <!--可以全写在db.properties里  也可以两边搭配混合都能实现效果,如果存在 优先使用外部配置文件-->
<!--        <property name="username" value="root"/>-->
<!--        <property name="password" value="123456"/>-->
    </properties>

    <!--default 切换环境-->
    <environments default="development">
        <!--开发环境-->
        <environment id="development">
            <!--事务管理器 默认事务处理器JDBC-->
            <transactionManager type="JDBC"/>
            <!--数据源 默认POOLED / UNPOOLED-->
            <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>
    <mappers>
        <mapper resource="mybatisstudy/dao/UserMapper.xml"/>
    </mappers>
</configuration>

配置文件映入注意点

  • 可以直接映入外部文件
  • 可以在其中增加一些属性配置
  • 如果两个文件有同一个字段 优先使用外部配置文件!

二.配置之别名优化

4.类型别名(typeAliases)

  • 类型别名可为 Java 类型设置一个缩写名字。
  • 意在降低冗余的全限定类名书写。

第一种:使用在实体较少的时候;灵活,可以DIY

<!--设置类型别名-->
    <typeAliases>
        <!--给实体类起别名-->
        <typeAlias type="mybatisstudy.pojo.User" alias="User"></typeAlias>
    </typeAliases>

第二种:实体十分多时建议使用,扫描包时可以通过注解起别名@Alias("")

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

扫描实体类的包,它的默认别名就为这个类的类名,首字母小写(建议),大写也没问题

<!--设置类型别名-->
<typeAliases>
    <!--配置包名-->
    <package name="mybatisstudy.pojo" />
</typeAliases>
@Alias("user")
public class User{}

5.设置(settings)

这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。

image.png

image.png

6.其他配置

三.配置之映射器说明

7.映射器(mappers)

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

  • 第一种:推荐使用
<!-- 使用相对于类路径的资源引用 -->
<mappers>
  <mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
  <mapper resource="org/mybatis/builder/BlogMapper.xml"/>
  <mapper resource="org/mybatis/builder/PostMapper.xml"/>
</mappers>
  • 第二种:不使用
<!-- 使用完全限定资源定位符(URL) -->
<mappers>
  <mapper url="file:///var/mappers/AuthorMapper.xml"/>
  <mapper url="file:///var/mappers/BlogMapper.xml"/>
  <mapper url="file:///var/mappers/PostMapper.xml"/>
</mappers>
  • 第三种: 使用class文件会存在一些问题:
    • 注意点:
      • 接口和它的Mapper配置文件必须同名
      • 接口和它的Mapper配置文件必须在用一个包
<!-- 使用映射器接口实现类的完全限定类名 -->
<mappers>
  <mapper class="org.mybatis.builder.AuthorMapper"/>
  <mapper class="org.mybatis.builder.BlogMapper"/>
  <mapper class="org.mybatis.builder.PostMapper"/>
</mappers>
  • 第四种:使用扫描包进行注入绑定(同扫描class一致)
    • 注意点:
      • 接口和它的Mapper配置文件必须同名
      • 接口和它的Mapper配置文件必须在用一个包
<!-- 将包内的映射器接口全部注册为映射器 -->
<mappers>
  <package name="org.mybatis.builder"/>
</mappers>