Mybatis-学习笔记(2)Mybatis配置文件
3》typeAliases:类型别名。2种指定方式。
1>给某个类起个别名
<typeAliases>
<typeAlias type="com.lfy.bean.Emp" alias="Emp"/>
</typeAliases>
2>指定包名
<!-- Mybatis将会搜索包名下需要的Java Bean,包下的Java Bean在没有注解的情况下,
会使用Bean的首字母小写来限定类名作为它的别名,如com.lfy.bean.Emp的别名
为emp;如果有注解别名,则以注解值为最终别名。 -->
<typeAliases>
<package name="com.lfy.bean.Emp"/>
</typeAliases>
@Alias("emp")
public class Emp{
...
}
Mybatis还为许多常见的类型内建了别名:


4》类型处理器

如何使用:
5》ObjectFactory对象工厂
Mybatis每次创建结果对象的新实例时,都会使用一个对象工厂实例来完成。默认的对象工厂需要做的仅仅是实例化目标类,要么通过默认构造方法,要么在参数映射存在的时候通过参数构造方法实例化。如果想覆盖对象工厂的默认行为,则可以通过创建自己的对象工厂来实现。
public class ExampleObjectFactory extends DefaultObjectFactory{
//处理默认构造器
public Object create(Class type){
return super.create(type);
}
//处理带参构造器
public Object create(Class type,List<Class> contructorArgTypes,List<Object> constructorArgs){
return super.create(type,contructorArgTypes,constructorArgs);
}
//配置ObjectFactory
public void setProperties(Properties properties){
super.setProperties(properties);
}
public <T> boolean isCollection(Class<T> type){
return Collection.class.isAssignableFrom(type);
}
}
配置文件中配置自定义的对象工厂:
<objectFactory type="com.lfy.factory.ExcempleObjectFactory">
<property name="someProperty" value="100"/>
</objectFactory>
6》environments配置环境:事务管理配置、数据源配置。
Mybatis的环境配置,实际是数据源的环境配置。可以将Mybatis配置到开发、测试、生产等多种环境的数据源,但SqlSessionFactory实例只能选择一个环境,即每个SqlSessionFactory对应一个数据库。如果想连接两个以上的数据库,只能创建多个SqlSessionFactory。
<environments default="oracle">
<environment id="oracle">
<!-- 指定事务管理类型,type="JDBC"指直接使用JDBC的提交与回滚 -->
<transactionManager type="JDBC" />
<!-- 配置数据库连接信息 -->
<dataSource type="POOLED">
<property name="driver" value="oracle.jdbc.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:orcl" />
<property name="username" value="scott" />
<property name="password" value="12345" />
</dataSource>
</environment>
<environment id="mysql">
<transactionManager type="JDBC" />
<!-- 配置数据库连接信息 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://127.0.0.1:3306/world" />
<property name="username" value="root" />
<property name="password" value="12345" />
</dataSource>
</environment>
</environments>
1)事务管理器有2种:
1>JDBC:直接使用了JDBC的提交和回滚设置,依赖于从数据源得到的连接来管理事务范围。
2>MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(如JAEE应用服务器的上下文)。默认情况下它会关闭连接,可以将closeConnection属性设置为false来阻止它默认的关闭行为。
<transactionManager type="MANAGED" >
<property name="closeConnection" value="false"/>
</transactionManager>
如果开发者使用Spring+Mybatis,则没有必要配置事务管理器,因为Spring模块会使用自带的管理器来覆盖前面的配置。
2)数据源配置,有3中数据源类型:
1>UNPOOLED:这种方式是每次被请求时打开和关闭连接。需要配置的5种连接属性:

2>POOLED:这种数据源的实现利用“池”的概念将JDBC连接对象组织起来,避免类创建新的连接实例时所必需的初始化和认证时间。这是一种使得并发Web应用快速响应请求的流行方式。还有更多的属性可以配置:

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

举个例子:
<dataSource type="JNDI">
<property name="initial_context" value="java:/comp/env"/>
<property name="data_source" value="some_dataSource">
</dataSource>
7》mapper映射器
主要是告诉Mybatis去哪里找映射sql。
<mappers>
<!-- 注册empMapper.xml文件-->
<mapper resource="com/lfy/mapping/empMapper.xml"/>
<mapper class="com.lfy.mapping.EmpMapper"/>
</mappers>
Mybatis-学习笔记(2)Mybatis配置文件的更多相关文章
- Mybatis学习笔记(一) —— mybatis介绍
一.Mybatis介绍 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名 ...
- Mybatis学习笔记(八) —— Mybatis整合spring
一.整合思路 1.SqlSessionFactory对象应该放到spring容器中作为单例存在. 2.传统dao的开发方式中,应该从spring容器中获得sqlsession对象. 3.Mapper代 ...
- MyBatis学习笔记(一)——MyBatis快速入门
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4261895.html 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优 ...
- 1.2(Mybatis学习笔记)Mybatis核心配置
一.Mybatis核心对象 1.1SqlSeesionFactory SqlSessionFactory主要作用是创建时SqlSession. SqlSessionFactory可通过SqlSessi ...
- Mybatis学习笔记(九) —— Mybatis逆向工程
一.什么是Mybatis逆向工程? 简单的解释就是通过数据库中的单表,自动生成java代码. 我们平时在使用Mabatis框架进行Web应用开发的过程中,需要根据数据库表编写对应的Pojo类和Mapp ...
- Mybatis学习笔记(二) —— mybatis入门程序
一.mybatis下载 mybaits的代码由github.com管理,下载地址:https://github.com/mybatis/mybatis-3/releases 下载完后的目录结构: 二. ...
- MyBatis学习笔记二:MyBatis生产中使用环境搭建
这里是在上一个环境的基础上修改的,这里就不在给出所有的配置,只给出哪里修改的配置 1.修改POJO对象为注解方式 2.创建Dao层接口 package com.orange.dao; import c ...
- MyBatis学习笔记一:MyBatis最简单的环境搭建
MyBatis的最简单环境的搭建,使用xml配置,用来理解后面的复杂配置做基础 1.环境目录树(导入mybatis-3.4.1.jar包即可,这里是为后面的环境最准备使用了web项目,如果只是做 my ...
- MyBatis学习笔记(七)——Mybatis缓存
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4270403.html 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓 ...
- Mybatis学习笔记导航
Mybatis小白快速入门 简介 本人是一个Java学习者,最近才开始在博客园上分享自己的学习经验,同时帮助那些想要学习的uu们,相关学习视频在小破站的狂神说,狂神真的是我学习到现在觉得最GAN的老师 ...
随机推荐
- test dword ptr [eax],eax ; probe page.局部数组变量定义所分配的最大空间为1M
问题的出现 使用VS2017编写程序时,程序编译可以通过,但运行时就会弹出错误 经过查证发现: 这跟局部数组变量定义所分配的最大空间设置大小有关. 局部变量的申请空间是存放于栈中,windows里默认 ...
- LTM_本地流量管理(一)
基本元素及概念 Node:节点,即服务器的IP地址. Member:成员,即一个服务,用IP+端口表示. Pool:池:一个或多个Member的逻辑分组,一个Pool表示一个应用,每个Pool都有自己 ...
- mysql Update语句 语法
mysql Update语句 语法 作用:用于修改表中的数据.广州大理石机械构件 语法:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 mysql Update语句 示例 ...
- BZOJ 4026: dC Loves Number Theory 可持久化线段树 + 欧拉函数 + 数学
Code: #include <bits/stdc++.h> #define ll long long #define maxn 50207 #define setIO(s) freope ...
- Nginx 在 Linux 下安装与搭建集群
搭建集群图例 集群搭建图如下,为了简单一点,使用一个Nginx服务器+两个Tomcat服务器,省略数据库部分: 环境说明 Linux 为 CentOS 7.2 发行版 + Java jdk 1.8 + ...
- tomcat安全配置参考
0x01 基本配置 1 删除默认目录 安装完tomcat后,删除$CATALINA_HOME/webapps下默认的所有目录文件 rm -rf /srv/apache-tomcat/webapps/ ...
- LDAP常见错误码
LDAP_SUCCESS = 0 //成功 LDAP_OPERATIONS_ERROR = 1 //操作错误 LDAP_PROTOCOL_ERROR = 2 //协议错误 LDAP_TIME_LIMI ...
- Xcode Server持续集成
这是一篇2017-11-12 年我还在 ezbuy 的一篇文章,时间过去很早了,最近在整理笔记的时候发现了, 同步过来,文章内容现在是否有效不确定,应该大差不差,读者仅做参考 最后更新 2017-11 ...
- Vue点击切换Class变化,实现Active当前样式
刚自学Vue不久,所以还不太熟,所以直接上代码. 一.先在data里增加一个变量,用来储存当前点击的元素 data() { return { activeClass: -1, // 0为默认选择第一个 ...
- Linux shell - 修改文件所属用户和组 (chown, chgrp)
在工作中,会遇到这样的情况,需要把目录所属的的root用户更改到普通用户,root组更改到普通组. sha-q:/ # ll drwxr-xr-x 2 root root 4096 2014-09-1 ...