mybatis核心配置文件介绍

发布时间:2024年01月14日

mybatis核心配置文件

1. properties配置介绍

properties标签:加载外部的资源配置文件

? 属性:resource 指定要引入的配置文件路径

? 在核心配置文件中,通过:${key}方式引入外部配置文件的数据

jdbc.peroperties 的文件内容如下

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/hsp_db02?useUnicode=true&characterEncoding=utf-8&useSSL=false
jdbc.username=root
jdbc.password=123456

在mybatis-config.xml引入如下配置

<?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="jdbc.properties"></properties>
    <!--配置数据源(数据库连接)-->
    <environments default="development">
        <environment id="development">
            <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="com/itheima/dao/UserMapper.xml"/>
    </mappers>
</configuration>

2.settings标签

<?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="jdbc.properties"></properties>
    <!--开启驼峰映射:把数据表中的带有下划线的字段,变为java的驼峰命名方式。user_name->username userName-->
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
    <!--配置数据源(数据库连接)-->
    <environments default="development">
        <environment id="development">
            <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="com/itheima/dao/UserMapper.xml"/>
    </mappers>
</configuration>

3.typeAliases标签

<?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="jdbc.properties"></properties>
    <!--开启驼峰映射:把数据表中的带有下划线的字段,变为java的驼峰命名方式。user_name->username userName-->
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
    <!--设置别名-->
    <typeAliases>
        <!--扫描指定的名,所包下的所有的类,都起了别名,别名格式:全部小写或驼峰命名-->
        <package name="com.itheima.pojo"/>
<!--        <typeAlias type="com.itheima.pojo.User" alias="User"></typeAlias>-->
    </typeAliases>
    <!--配置数据源(数据库连接)-->
    <environments default="development">
        <environment id="development">
            <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="com/itheima/dao/UserMapper.xml"/>
    </mappers>
</configuration>

4.typeHandlers和environments

4.1typeHandlers

MyBatis在设 置预处理语句(PreparedStatement)中的参数或从结果集中取出一个值时,都会用类型处理器将获取到的值以合适的方式转换成java类型

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--利用namespace属性,绑定当前映射文件和mapper接口映射关联-->
<mapper namespace="com.itheima.dao.UserMapper">
    <!--SQL查询文件-->
    <select id="findAllUser" resultType="User">
        select id,username,birthday,sex,address from tb_user
    </select>
    <select id="findName" resultType="string">
        select user_name from tb_user where id=1
        <!--user_name 在mysql中是varchar
            java语言中varchar类型,使用String

            mybatis底层利用TypeHandler,实现varchar =>String
        -->
    </select>
</mapper>

4.2environments

MyBatis可以配置成适应多种环境,例如,开发、测试和生产环境需要有不同的配置,尽管可以配置多个环境,每个SqlSessionFactory实例只能选择期一。

虽然,这种方式也可以做到很方便的分离多个环境,但是实际使用场景下,我们更多的是选择使用Spring来管理数据源来做到环境的分离

? 父标签:environments

? 子标签:environment

<?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="jdbc.properties"></properties>
    <!--开启驼峰映射:把数据表中的带有下划线的字段,变为java的驼峰命名方式。user_name->username userName-->
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
    <!--设置别名-->
    <typeAliases>
        <!--扫描指定的名,所包下的所有的类,都起了别名,别名格式:全部小写或驼峰命名-->
        <package name="com.itheima.pojo"/>
<!--        <typeAlias type="com.itheima.pojo.User" alias="User"></typeAlias>-->
    </typeAliases>
    <!--配置数据源(数据库连接)-->
    <environments default="dev">
        <!--开发环境-->
        <environment id="dev">
            <!--事务管理器:按照jdbc默信的事务-->
            <transactionManager type="JDBC"/>
            <!--数据源(数据库连接池) mybatis有自带数据库连接池-->
            <dataSource type="POOLED">
                <!--连接数据库需要的4个参数:驱动、URL、登录名、密码-->
                <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>
        <!--测试环境-->
        <environment id="test">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/hsp_db02?useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <!--映射映射相关文件-->
    <mappers>
        <mapper resource="com/itheima/dao/UserMapper.xml"/>
    </mappers>
</configuration>

5.mapper(映射器)

? mapper标签的作用:提供了关联了加载XML映射文件件的配置功能;

? 使用方式:

? 1.加载XML映射文件,关联UserMapper.java接口

? 【1】

? 说明:如果项目采用基于XML的开发模式,建议使用方式1的开发

? 2.加载接口,关联映映射文件

? 条件:接口名和映射文件名保持一致,路径保持一致

? 【2】批量加载class:

? 说明如果是基于注解开发的话,推荐使用方式2开发

<?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="jdbc.properties"></properties>
    <!--开启驼峰映射:把数据表中的带有下划线的字段,变为java的驼峰命名方式。user_name->username userName-->
    <settings>
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
    <!--设置别名-->
    <typeAliases>
        <!--扫描指定的名,所包下的所有的类,都起了别名,别名格式:全部小写或驼峰命名-->
        <package name="com.itheima.pojo"/>
<!--        <typeAlias type="com.itheima.pojo.User" alias="User"></typeAlias>-->
    </typeAliases>
    <!--配置数据源(数据库连接)-->
    <environments default="dev">
        <!--开发环境-->
        <environment id="dev">
            <!--事务管理器:按照jdbc默信的事务-->
            <transactionManager type="JDBC"/>
            <!--数据源(数据库连接池) mybatis有自带数据库连接池-->
            <dataSource type="POOLED">
                <!--连接数据库需要的4个参数:驱动、URL、登录名、密码-->
                <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>
        <!--测试环境-->
        <environment id="test">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/hsp_db02?useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <!--映射映射相关文件-->
    <mappers>

        <!--方案1:指定关联的映射文件,通过映射文件在关联mapper接口-->
<!--        <mapper resource="com/itheima/dao/UserMapper.xml"/>-->
        <!--方案1:指定关联的mapper接口(通过mapper接口关联映射文件)
            要求:
                1.映射文件名和mapper接口必须相同
                2.映射文件和mapper接口存储在相同的路径下
        -->
        <!--指定要扫描的所有mapper接口的包路径-->
        <package name="com.itheima.dao"/>
    </mappers>
</configuration>
erMapper.xml"/>-->
        <!--方案1:指定关联的mapper接口(通过mapper接口关联映射文件)
            要求:
                1.映射文件名和mapper接口必须相同
                2.映射文件和mapper接口存储在相同的路径下
        -->
        <!--指定要扫描的所有mapper接口的包路径-->
        <package name="com.itheima.dao"/>
    </mappers>
</configuration>
文章来源:https://blog.csdn.net/lisus2007/article/details/135579877
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。