博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

MyBatis - 03核心配置文件

Posted on 2020-11-23 21:36  Kingdomer  阅读(51)  评论(0编辑  收藏  举报

MyBatis - 03核心配置文件

(1)MyBatis核心配置文件层级关系

  • configuration 配置
    • properties 属性
    • settings 设置
    • typeAliases 类型别名
    • typeHandlers 类型处理器
    • objectFactory 对象工厂
    • plugins 插件
    • environments 环境
      • environment 环境变量
        • transactionManager 事务管理器
        • dataSource 数据源
    • databaseIdProvider 数据库厂商标识
    • mappers 映射器
标签在核心配置文件中的配置顺序:
Caused by: org.xml.sax.SAXParseException; lineNumber: 36; columnNumber: 17; 元素类型为 "configuration" 的内容必须匹配 "(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,reflectorFactory?,plugins?,environments?,databaseIdProvider?,mappers?)"。
 

(2)MyBatis 常用配置解析

(2.1)enviroments标签

数据库环境配置,支持多环境配置

    <!--数据源环境-->
    <environments default="development">   // 指定默认的环境名称
        <environment id="development">     // 指定当前环境名称
            <transactionManager type="JDBC"></transactionManager>  // 指定事务管理类型是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>

> 事务管理器(transactionManager)类型有两种:

JDBC:    这个配置直接使用了jdbc的提交和回滚配置,依赖于从数据源得到的连接来管理事务作用域。

MANAGED: 这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如J2EE应用服务器上下文)。

          默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false来阻止默认的关闭行为。

> 数据源(dataSource)类型有三种:

UNPOOLED: 这个数据源的实现只是每次被请求时打开和关闭连接。

POOLED:   这个数据源的实现利用"池"的概念将jdbc连接对象组织起来。

JNDI:     这个数据源的实现是为了能在如EJB或应用服务器这类容器中使用。容器可以集中或在外部配置数据源,然后放置一个JNDI上下文的引用。

(2.2)mapper标签

该标签的作用是加载映射,加载方法有如下几种:

   > 使用相对于类路径的资源引用,例如 <mapper resource="mapper/UserMapper.xml"/>

   > 使用完全限定资源定位符(URL),例如 <mapper url="file:///var/mapper/UserMapper.xml"/>

   > 使用映射器接口实现类的完全限定类名,例如 <mapper class="com.bearpx.dao.UserMapper"/>

   > 将包内的映射器接口实现全部注册为映射器,例如 <package name="com.bearpx.dao"/>

    <!--加载映射文件-->
    <mappers>
        <mapper resource="mapper/UserMapper.xml"></mapper>
    </mappers>

(2.3)Properties标签

将数据源的配置信息单独抽取成一个properties文件,该标签可以加载外部配置的properties文件

    <!--通过properties标签加载外部properties文件-->
    <properties resource="jdbc.properties"></properties>

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

(2.4)typeAliases标签

类型别名是为java类型设置一个短的名字。mybatis框架已经设置好的一些常用的类型的别名:

别名 <-> 数据类型   string <-> String 、long <-> Long 、int <-> Integer 、double <-> Double 、 boolean <-> Boolean

    <!--自定义别名-->
    <typeAliases>
        <typeAlias type="com.bearpx.spring.mybatis.domain.User" alias="user"></typeAlias>
    </typeAliases>

 

    <select id="findAll" resultType="user">   // resultType由 com.bearpx.spring.mybatis.domain.User 改成 user
        select * from user
    </select>