MyBatis-mybatis全局映射文件解析

全局配置文件为mybatis-config.xml

1、properties标签

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

可以使用properties来引入外部properties配置文件的内容

引入方式有两种:

  ①resource:引入类路径下的资源

  ②url:引入网络路径或者磁盘路径下的资源

2、settings标签  

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

settings包含很多重要的设置项

setting:用来设置每一个设置项 name:设置项名 value:设置项取值

具体参见:http://www.mybatis.org/mybatis-3/zh/configuration.html#settings

3、typeAliases

<typeAliases>
   <typeAlias type="com.atguigu.mybatis.bean.Employee" alias="emp"/>
   <package name="com.atguigu.mybatis.bean"/>
</typeAliases>

typeAliases别名处理器:可以为我们的java类型起别名,别名不区分大小写。

①typeAlias:为某个java类型起别名

      type:指定要起别名的类型全类名;默认别名就是类名小写;

      alias:指定新的别名

②package:为某个包下的所有类批量起别名

      name:指定包名(为当前包及下面所有的后代包的每一个类都起一个默认的别名(类名小写))

      批量起别名的情况下,可以使用@Alias注解为某个类型指定新的别名。

4、environments标签

<environments default="dev_mysql">
        <environment id="dev_mysql">
            <transactionManager type="JDBC"></transactionManager>
            <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>

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

  myBatis可以配置多种环境,default指定使用某种环境,可以达到快速切换环境。  

  ①environment:配置一个具体的环境信息:必须有两个标签Id代表当前环境的唯一标识。

  ②transactionManager:事务管理器

    type:事务管理器的类型;JDBC(JdbcTransactionFactory)|MANAGED(ManagedTransactionFactory)。

       自定义事务管理器:实现TransactionFactory接口.type指定为全类名

  ③dataSource:数据源。

    type:数据源类型;UNPOOLED(UnpooledDataSourceFactory)|POOLED(PooledDataSourceFactory)|JNDI(JndiDataSourceFactory)

    自定义数据源:实现DataSourceFactory接口,type是全类名

5、databaseIdProvider标签 支持多数据厂商的

<databaseIdProvider type="DB_VENDOR">
        <!-- 为不同的数据库厂商起别名 -->
        <property name="MySQL" value="mysql"/>
        <property name="Oracle" value="oracle"/>
        <property name="SQL Server" value="sqlserver"/>
</databaseIdProvider>

    在SQL映射文件中可以指定所用的数据库id,即使用哪个数据库厂商。在databaseId中指定 

    <select id="getEmployeeById" resultType="Employee" databaseId="mysql" >
        SELECT id ,user_name,gender,email FROM tbl_employee WHERE id
        = #{id}
    </select>

7、mappers标签 将SQL映射注册到全局配置中

  将我们写好的sql映射文件(EmployeeMapper.xml)一定要注册到全局配置文件(mybatis-config.xml)中

  ①注册一个sql映射注册配置文件

<mappers>
     <mapper resource="mybatis/mapper/EmployeeMapper.xml"/>
</mappers>

    resource:引用类路径下的sql映射文件

    url:引用网络路径或者磁盘路径下的sql映射文件(file:///var/mappers/AuthorMapper.xml)

  ②注册一个接口      

<mappers>
    <mapper class="com.atguigu.mybatis.dao.EmployeeMapperAnnotation"/>
</mappers>

    class:引用(注册)接口,

        有sql映射文件,映射文件名必须和接口同名(忽略大小写),并且放在与接口同一目录下

        没有sql映射文件,所有的sql都是利用注解写在接口上

    推荐:比较重要的复杂的DAO接口我们来写sql映射文件,不重要的,简单的Dao接口为了开发快速可以使用注解

    如果采用接口注册,mapper sql映射文件中的nameSpace属性必须是接口的全类名。

  ③批量注册       

<mappers>
    <package name="com.atguigu.mybatis.dao"/>
</mappers>

  

时间: 2024-10-03 14:02:18

MyBatis-mybatis全局映射文件解析的相关文章

mybatis 中 sql 映射文件 select 标签以及 入 resultMap 标签的应用

1.自定义某个 javabean 的封装规则: 注:可以看到,select 标签中引用了 定义好的 resultMap 的值.resultMap 标签中的 type 为javabean 类型,id 为唯一标识.id 子标签定义主键(这样定义底层会有优化.)column 属性为字段名,property 属性为字段值. 注:可以看到测试结果没有出现问题,说明代码没有错误. 2.自定义某个 javabean 的级联属性封装: a.准备工作:mysql 数据库中,在之前 tbl_employees 表的

mybatis 学习三 关键文件解析

1:  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> <

MyBatis之sql映射文件

MyBatis的强大之处就在于它的sql映射文件,下面介绍sql映射文件的几个顶级元素配置 1)mapper:映射文件的根元素节点,只有一个namespace(命名空间) * 用于区分不同的mapper,全局唯一 * 绑定dao接口,即面向接口编程, 当,namespace绑定某一接口之后,可以不用写该接口的实现类,MyBatis会通过接口的完整的限定名查找到对应的mapper配置来执行sql语句,应此namespace的命名必须要跟接口同名. 2)cache:配置给定的命名空间的缓存 3)ca

MyBatis的SQL映射文件

1.使用MyBatis实现条件查询 (1)sql映射文件 mapper:映射文件的根元素节点,只有一个属性namespace,其作用如下: <1>用于区分不同的mapper,全局唯一 <2>绑定DAO接口,即面向接口编程.当namespace绑定某一接口之后,可以不用写该接口的实现类,MyBatis会通过接口的完整限定名查找到对应的mapper配置来执行SQL语句.因此namespace的命名必须要跟接口同名. cache:配置给定命名空间的缓存 cache-ref:从其他命名空间

mybatis的mapper映射文件中where,if,foreach等的使用

<?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:命名空间,用于隔离sql,还有一个很重要的作用,后面会讲 --> &

MyBatis——Mapper.xml映射文件

Mapper.xml映射文件 转载:http://loveshisong.cn/mybatis/2015/01/22/MyBatis(%E4%B8%89)Mapper.xml%E6%98%A0%E5%B0%84%E6%96%87%E4%BB%B6.html 本文结构 select 语句简介 insert update delete 简介 Parameters 参数 ResultMap select 语句简介 查询语句是 MyBatis 中最常用的元素之一,先来个例子 <select id="

mybatis 的 sql 映射文件增删改查的学习

在 sql 映射文件中配置增删改查的操作:     1.增: 在 sql 映射文件中添加 insert 标签,并且增加对应的 sql 语句.(在之前博文示例的基础上添加)在 对应的接口中添加 对应的方法,方法名与 sql 映射文件中 insert 标签中的 id 属性值一致. 注:可以看到,在测试方法 test03 中更新成功.但是在 openSession 对象需要手动提交事务.(sqlSessionFactory.openSession 方法的得到的 openSession 对象,使用 sq

【三】MyBatis的SQL映射文件 ----- 一对多的关联查询

一对多关联查询的解决方案也有两种:嵌套结果和嵌套查询 在上一篇博客中已经讲了一对一的关联查询,在MySQL数据库中已经存在了班级表 class 和教师表 teacher.为了满足一对多关联查询的要求,还需要创建一张学生表 student.这样,在查询班级信息的同时,可以得到教师和学生的信息. 创建 student 表的 SQL 语句如下: CREATE TABLE student( s_id INT PRIMARY KEY AUTO_INCREMENT, s_name VARCHAR(20),

【二】MyBatis的SQL映射文件 ----- 一对一的关联查询

现在假设数据库中有两张表,一张是班级表,另一张是教师表.一个班级只有一名班主任老师,而一个老师只能担任一个班的班主任,这就是我们所说的一对一关联关系.现在要求,查询班级表的同时也要查询出老师的信息.两张表的数据如下所示: 教师表: 班级表: 创建表的SQL语句如下(MySQL数据库): CREATE TABLE teacher( t_id INT PRIMARY KEY AUTO_INCREMENT, t_name VARCHAR(20) ); CREATE TABLE class( c_id