Mybatis——xml配置

注:该文档参考了

一.配置属性(properties)

目标:解耦

  1. 直接在mybatis-config.xml配置
<dataSource type="POOLED">
  <property name="driver" value="driver"/>
  <property name="url" value="url"/>
  <property name="username" value="username"/>
  <property name="password" value="password"/>
</dataSource>
  1. 通过properties属性配置
<properties resource="db.properties">
        <property name="username" value="username"/>
        <property name="password" value="password"/>
</properties>

<environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/dailyClick-test?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>

            </dataSource>
        </environment>
    </environments>
  1. 使用配置文件位置
    (1).在resources目录下建立一个配置文件目录:config.properties
username=username
password=password

(2).在mybatis-config.xml中将config.properties中的内容引入,同时改换占位符

<properties resource="db.properties">
</properties>

<environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://47.100.90.132:3306/dailyClick-test?useSSL=false&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>

            </dataSource>
        </environment>
    </environments>

注:

  • 在xml中,所有的标签都可以规定其顺序
  • #{}多应用于sql语句,也是应用于spring的xml配置和注解配置中统一的SpEL表达式语法结构.${}多应用于配置文件中(如:xml),是属性占位符,配合spring的property-placeholder和.property文件使用,将spring中的配置信息提取到文件中,方便修改,其功能完全可用#{}代替,但${}更简单不易错

加载顺序:

  1. 首先读取在 properties 元素体内指定的属性。
  2. 然后根据 properties 元素中的 resource 属性读取类路径下属性文件,或根据 url 属性指定的路径读取属性文件,并覆盖之前读取过的同名属性
  3. 最后读取作为方法参数传递的属性,并覆盖之前读取过的同名属性

二.设置(settings):

这里挑选几个重要的setting

  1. cacheEnabled(true | false):全局性地开启或关闭所有映射器配置文件中已配置的任何缓存。
  2. lazyLoadingEnabled(true | false):懒加载.延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 fetchType 属性来覆盖该项的开关状态。简单来说,就是什么时候用,什么时候加载
  3. mapUnderscoreToCamelCase(true | false):是否开启驼峰命名自动映射,即从经典数据库列名 A_COLUMN 映射到经典 Java 属性名 aColumn。
  4. logImpl(SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING):指定 MyBatis 所用日志的具体实现,未指定时将自动查找。

配置方式

<settings>
  <setting name="cacheEnabled" value="true"/>
  <setting name="lazyLoadingEnabled" value="true"/>
</settings>

三.类型别名(typeAliases)

类型别名可为 Java 类型设置一个缩写名字。 它仅用于 XML 配置,意在降低冗余的全限定类名书写.
java的基础数据数据类型和基础类都几乎有别名,如:int->_int(注意这里八大基础类型都有"_"前缀),Map->map

  1. 通过typeAlias属性配置
<typeAliases>
  <typeAlias alias="Author" type="domain.blog.Author"/>
</typeAliases>

注:这里需要定位到相关的Bean类

  1. 通过package属性配置
<typeAliases>
  <package name="domain.blog"/>
</typeAliases>

非限定(non-qualified)类名:也叫短名,就是我们平时说的类名,不带包
注:这里默认会使用 Bean 的首字母小写的非限定类名来作为它的别名

3.通过package属性+注解配置

@Alias("author")
public class Author {
    ...
}

总结:
(1). 当实体类较少时,使用第一种方式,可以起别名
(2). 如果实体类较多,且不用起别名,可以用第二种方式
(3). 如果实体类较多,且需要起别名,可以用第三种方式,但注意随意的加注解会降低程序的可阅读性

四.环境配置(environments)

  1. 环境配置

MyBatis 可以配置成适应多种环境,这种机制有助于将 SQL 映射应用于多种数据库之中.每个数据库对应一个 SqlSessionFactory 实例

<environments default="development">
  <environment id="development">
    <transactionManager type="JDBC">
      <property name="..." value="..."/>
    </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>

注:
(1).默认使用的环境 ID,也就是当前实际使用的环境(比如:default="development")
(2).每个 environment 元素定义的环境 ID(比如:id="development")
(3).事务管理器的配置(比如:type="JDBC")
(4).数据源的配置(比如:type="POOLED")

2.事务管理器

这里只需要知道有两个事物管理器即可

type="[JDBC|MANAGED]"

五.映射器

定义SQL映射语句后,告诉 MyBatis 到哪里去找到这些语句
1.使用相对于类路径的资源引用

<mappers>
  <mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
</mappers>
  1. 使用映射器接口实现类的完全限定类名
<mappers>
  <mapper url="file:///var/mappers/AuthorMapper.xml"/>
</mappers>
  1. 将包内的映射器接口实现全部注册为映射器
<mappers>
  <package name="org.mybatis.builder"/>
</mappers>

注意:
(1). 接口和他的Mapper配置文件必须同名
(2). 接口和他的Mapper配置文件必须在同一个包下
推荐第一种方式

posted @ 2020-07-22 20:33  Arno_vc  阅读(198)  评论(0编辑  收藏  举报