2023-01-09

一、Mybatis核心配置文件概述及根标签

1、核心配置文件的概述(即“mybatis-config.xml”)

MyBatis的配置文件包含了会深深影响MyBatis行为的设置和属性信息。

2、标签

(1)configuration(配置)

(2)properties(属性)

作用:定义或引入外部属性文件

在“day02_mybatis.src.main.resources”文件夹下创建“数据库的连接文件”,命名为“db.properties”

①db.properties里面的内容

#里面存放的数据格式为key=valuedb.driver=com.mysql.cj.jdbc.Driverdb.url=jdbc:mysql://localhost:3306/db220106?serverTimezone=UTCdb.username=设置自己的数据库的用户名称db.password=数据库的密码

②“day02_mybatis.src.main.resources”下的“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>    <properties resource="db.properties"></properties>    <environments default="development">        <environment id="development">            <transactionManager type="JDBC"/>            <dataSource type="POOLED">                <property name="driver" value="${db.driver}"/>                <property name="url" value="${db.url}"/>                <property name="username" value="${db.username}"/>                <property name="password" value="${db.password}"/>            </dataSource>        </environment>    </environments>    <!--设置映射文件-->    <mappers>        <mapper resource="mapper/EmployeeMapper.xml"/>    </mappers></configuration>

③“day02_mybatis.src.test.java.TestMybatis”中的代码

import com.hh.mybatis.mapper.EmployeeMapper;import com.hh.mybatis.pojo.Employee;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import java.io.IOException;import java.io.InputStream;public class TestMybatis {    @Test    public void TestMybatis(){        try {            String resource = "mybatis-config.xml";            InputStream inputStream = Resources.getResourceAsStream(resource);            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);            //通过sqlSessionFactory获取sqlSession对象            SqlSession sqlSession = sqlSessionFactory.openSession();            //获取EmployeeMapper的代理对象            EmployeeMapper employeeMapper = sqlSession.getMapper(EmployeeMapper.class);            System.out.println("employeeMapper.getClass().getName() = " + employeeMapper.getClass().getName());            Employee employee = employeeMapper.selectEmployee(1);            System.out.println("employee = " + employee);        } catch (IOException e) {            e.printStackTrace();        }    }}

④测试代码,代码OK

(3)settings(设置)

①作用:这是MyBatis中极为重要的调整设置,它们会改变MyBatis的运行行为

②例如:mapUnderscoreToCamelCase属性:表示是否开启驼峰命名自动映射,默认值是false,如设置true会自动将字段last_name与lastName属性自动映射。

③在“day02_mybatis.src.main.resources”下的“mybatis-config.xml”中的“”设置

<settings>        <setting name="mapUnderscoreToCamelCase" value="true"/></settings>

(4)typeAliases(类型别名)

①作用:类型别名可为java类型设置一个缩写名字。

②xml代码:

<typeAliases>        <typeAlias type="com.hh.mybatis.pojo.Employee" alias="employee"></typeAlias></typeAliases>

其中的xml代码也可以简写为

 <typeAliases>        <package name="com.hh.mybatis.pojo"/></typeAliases>

③之后,可以将“day02_mybatis.src.mian.resources.mapper”下的“EmployeeMapper.xml”中的“resultType”设置为“employee”,如下:

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"        "https://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.hh.mybatis.mapper.EmployeeMapper">    <select id="selectEmployee" resultType="employee">        SELECT            id,            last_name,            email,            salary        FROM            tbl_employee        WHERE            id=#{empId}    </select></mapper>

(5)typeHandlers(类型处理器)

(6)objectFactory(对象工厂)

(7)plugins(插件)

(8)environments(环境配置)

①作用:设置数据库的连接环境

②实例xml代码

  <environments default="development">        <environment id="development">            <transactionManager type="JDBC"/>            <dataSource type="POOLED">                <property name="driver" value="${db.driver}"/>                <property name="url" value="${db.url}"/>                <property name="username" value="${db.username}"/>                <property name="password" value="${db.password}"/>            </dataSource>        </environment>    </environments>

(9)databaseldProvider(数据库厂商标识)

(10)mappers(映射器)

①作用:设置映射文件路径

②xml代码:

例如:

<!--设置映射文件-->    <mappers>        <mapper resource="mapper/EmployeeMapper.xml"/>    </mappers>

3、注意事项

核心配置中的子标签,是有顺序要求的。顺序如下: