美文网首页我爱编程
SqlMapConfig.xml(Mybatis的全局配置文件)

SqlMapConfig.xml(Mybatis的全局配置文件)

作者: Stringer | 来源:发表于2016-11-20 23:04 被阅读326次

    SqlMapConfig.xml中配置的内容和顺序如下:

    properties(属性)

    settings(全局配置参数)

    typeAliases(类型别名)

    typeHandlers(类型处理器)

    objectFactory(对象工厂)

    plugins(插件)

    environments(环境集合属性对象)

    environment(环境子属性对象)

    transactionManager(事务管理)

    dataSource(数据源)

    mappers(映射器)

    properties(属性)
    需求: 将数据库连接参数单独配置在db.properties中,只需要在SqlMapConfig.xml中加载db.properties的属性值,在SqlMapConfig.xml中就不需要对数据库的连接参数硬编码

    注意:Mybatis按照下面的顺序来加载属性
    1.在properties元素体内定义的属性首先被读取(不建议使用)
    2.然后读取properties元素中的resource或url加载的属性,它会覆盖已读取的同名属性
    3.最后读取parameterType传递的属性,它会覆盖已读取的同名属性

    优先级:parameterType>resource或url>properties

    settings(全局配置参数)
    Mybatis框架在运行是可以调整一些运行参数
    比如:开启二级缓存,开启延迟加载

    typeAliases(类型别名)
    需求:
    在mapper.xml中,定义很多的statement,statement需要定义parameterType指定输入参数的类型、需要resultType指定输出结果的类型

    如果在指定类型时输入类型的全路径,不方便开发,可以针对parameterType或resultType指定的类型定义一些别名

    typeHandlers(类型处理器)
    Mybatis中通过typeHandlers完成jdbc类型和java类型之间的转换
    一般不需要自定义,Mybatis提供的类型处理器能满足日常需要

    mappers(映射器)

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
        <!-- 加载属性文件 -->
        <properties resource="db.properties">
            <!-- properties中还可以配置一些属性名和属性值 -->
            <!-- <property name="" value=""/> -->
        </properties>
        <!-- <settings></settings> -->
        <!-- 别名的定义 -->
        <typeAliases>
            <!-- 针对单个别名的定义
                type:类型的路径
                alias:别名
             -->
            <!-- <typeAlias type="cn.ztc.mybatis.po.User" alias="user"/> -->
            <!-- 批量别名的定义(常用)
                name:指定包名,Mybatis会自动扫描包中的po类。自动定义别名,别名就是类名,首字母大写小写都可
             -->
            <package name="cn.ztc.mybatis.po"/>
        </typeAliases>
        <!-- 和spring整合后 environments配置将废除-->
        <environments default="development">
            <environment id="development">
            <!-- 使用jdbc事务管理-->
                <transactionManager type="JDBC" />
            <!-- 数据库连接池-->
                <dataSource type="POOLED">
                    <property name="driver" value="${jdbc.driver}" />
                    <property name="url" value="${jdbc.url}" />
                    <property name="username" value="${jdbc.username}" />
                    <property name="password" value="${jdbc.password}" />
                </dataSource>
            </environment>
        </environments>
        <!-- 加载映射文件 -->
        <mappers>
            <mapper resource="sqlmap/User.xml"/>
            <!-- 通过resource加载单个映射文件 -->
            <!-- <mapper resource="mapper/UserMapper.xml"/> -->
            <!-- 通过mapper接口加载 
                规范:需要将mapper接口的类名和mapper.xml映射文件名称保持一致,且在同一个目录中
                上边规范的前提是,使用的是mapper代理的方法
            -->
            <!-- <mapper class="cn.ztc.mybatis.mapper.UserMapper"/> -->
            <!-- 批量加载 
                name:mapper接口的包名
            -->
            <package name="cn.ztc.mybatis.mapper"/>
            
            
        </mappers>
    </configuration>
    

    相关文章

      网友评论

        本文标题:SqlMapConfig.xml(Mybatis的全局配置文件)

        本文链接:https://www.haomeiwen.com/subject/opmypttx.html