Mybatis--配置解析、Mapper配置

86 阅读3分钟

核心配置文件

  1. 正常被我们命名为 mybatis-config.xml
  2. 核心配置文件包含了会深深影响MyBatis行为的设置和属性信息。
  3. 具体内容:
configuration(配置)
    properties(属性)
    settings(设置)
    typeAliases(类型别名)
    typeHandlers(类型处理器)
    objectFactory(对象工厂)
    plugins(插件)
    environments(环境配置)
    	environment(环境变量)
    		transactionManager(事务管理器)
    		dataSource(数据源)
    databaseIdProvider(数据库厂商标识)
    mappers(映射器)
configuration(配置)

注意: 核心配置文件的书写,是有顺序的,比如说,你把 setting 配置写在 properties 配置前面,就会报错。

环境配置

  1. Mybatis可以配置适应多种环境,但是每个SqlSessionFactory实例只能选择一种环境。
  2. MyBatis默认的事务管理器:JDBC transactionManager type="JDBC"
  3. MyBatis默认的连接池:POOLED dataSource type="POOLED"
  4. Mybatis通过default="development"属性设置默认的连接环境
<environments default="development"> 
        <environment id="development">
            <transactionManager type="JDBC"/>
            <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>
        <environment id="tdevelopment2">
            <transactionManager type="JDBC"/>
            <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>

属性配置

  1. 为什么要使用properties属性来配置文件?--> 方便管理和修改,容易维护。
  2. 怎么做? --> 编写配置文件,如数据库的properties文件 db.properties,编写完后在核心配置文件中引入即可。

db.properties

driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
username=root
password=123456

核心配置文件引入,注意引入的位置,有顺序要求!!!

<properties resource="db.properties"/>

注: 你还可以在核心配置文件中增加一些属性配置,比如说,

db.properties

driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
<properties resource="db.properties">
    <property name="username" value="root"/>
    <property name="password" value="123456"/>
</properties>

上面两种的效果相同。而且,如果在db.peoperties中和核心配置文件中都配置了同一字段的属性,比如说 username 和 password ,优先使用外部配置文件,即 db.properties

类型别名

  1. 为什么要使用别名? --> 降低冗余的全限定类名书写。
  2. 直接以我上一篇blog的例子来说,如果传递的参数是一个用户,需要写的代码为resultType="com.wu.pojo.User" 或者 parameterType="com.wu.pojo.User" ,这样子写就显得代码非常的难看,所以才有了别名的设置。
  3. 别名设置:直接在核心配置文件添加typeAliases配置
    <!--方式一-->
    <typeAliases>
        <typeAlias type="com.wu.pojo.User" alias="user"/>
    </typeAliases>
    <!--方式二-->
    <typeAliases>
        <package name="com.wu.pojo"/>
    </typeAliases>

用方式一修改完后,com.wu.pojo.User就可以改为user 别名=user 用方式二修改,别名是 实体类的类名,首字母小写 (不小写好像也可以,但是规范是改成小写)

  1. 区别和建议:
  • 在实体类比较少的时候,使用方式一。
  • 如果实体类十分多,建议用方式二扫描包的方式。
  • 方式一可以自定义 别名的名称,方式二一般情况下不可以
  • 如果使用方式二也要自定义别名,则需要在实体类添加注解,即:@Alias("user")

settings配置

  1. settings是MyBatis中极为重要的调整设置,会改变Mybatis的运行时行为。
  2. 具体需要的配置,需要的时候查看官方帮助文档 mybatis.org/mybatis-3/z…

Mapper配置

三种方式(url方式是从网络上引用,不推荐使用)

image.png

方式一:【推荐使用】

<mappers>
    <mapper resource="com/wu/dao/UserMapper.xml"/>
</mappers>

方式二:使用class文件绑定注册

<mappers>
    <mapper class="com.wu.dao.UserMapper"/>
</mappers>

方式三:使用包扫描进行注入

<mappers>
    <package name="com.wu.dao"/>
</mappers>

如果使用classpackage的话,必须满足以下两个条件:

  1. 接口和他的Mapper配置文件必须同名
  2. 接口和他的Mapper配置文件必须在同一个包下