MyBatis笔记二:配置

Stella981
• 阅读 514

MyBatis笔记二:配置

1.全局配置

1.properites

这个配置主要是引入我们的 properites 配置文件的:

<properties resource="db.properties"/>

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

可以看到我们使用 <properties resource="db.properties"/> 引入了我们的数据据库的配置文件,然后这个标签有两个属性 : resourceuri 第一种直接是引用项目下的文件。第二个就是引用网络路径的和我们本地文件系统的资源。

2.settings

非常重要!!!

<!--全局配置-->
<settings>
    <setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>

装了Mybatis 插件的话我们会看到我们的设置的代码提示,都不用自己去记的。

3.typeAliases

可以为我们的 Java 类型取别名。避免我们去写很长的类包名,等等。并且这里提供了三种取别名的方式:

1. typeAlias

<typeAliases>
    <typeAlias type="lwen.entries.Employee" alias="emp"/>
</typeAliases>
    

这就是给我们的 Java 类取的别名,我们在 xml 中配置返回值,参数,命名空间的时候就不用写那么长了。我们直接写 emp 即可,但是注意的是我们如果不写 alias 属性他就会配置默认的别名,也就是我们的类名首字母小写。在这里就是employee

2.package

批量取别名,有时候我们的一个包下面的类太多了我们希望给他们都取上默认别名,我们就可以使用这个标签,但是注意这个标签不能和 typeAlias标签共存 ,这个标签指定的包其实是对我们的这个包以及他的子包进行别名操作,并且都是默认别名

<typeAliases>
    <package name="lwen.entries"/>
</typeAliases>

3.@Alias

因为上面的两个标签不能同时存在,所以我们没办法给某一个包下的特定的类取别名,这里我们就需要使用 @Alias 来做注解别名了,这样可以解决上面的问题。

@Alias("emps")

其实除了这些我们需要自定义的一些别名,系统帮我们预先设定好了很多常用的别名

别名

映射的类型

_byte

byte

_long

long

_short

short

_int

int

_integer

int

_double

double

_float

float

_boolean

boolean

string

String

byte

Byte

long

Long

short

Short

int

Integer

integer

Integer

double

Double

float

Float

boolean

Boolean

date

Date

decimal

BigDecimal

bigdecimal

BigDecimal

object

Object

map

Map

hashmap

HashMap

list

List

arraylist

ArrayList

collection

Collection

iterator

Iterator

可以看到规律就是类名小写,然后基本类型就是下划线。

4.typeHandler

这个东西其实就是把我们的Java类型和数据库的类型相对应,这里暂时不具体说。

5.plugins

插件功能,对下面对象的方法进行拦截,他的原理就是动态代理。

  • Executor (update, query, flushStatements, commit, rollback, getTransaction, close, isClosed)
  • ParameterHandler (getParameterObject, setParameters)
  • ResultSetHandler (handleResultSets, handleOutputParameters)
  • StatementHandler (prepare, parameterize, batch, update, query)

6.environments

<environments default="dev">
    <environment id="dev">
        <transactionManager type="JDBC">
            <property name="hah" value="heh"/>
        </transactionManager>
        <dataSource type="POOLED">
            <property name="password" value="${password}"/>
        </dataSource>
    </environment>
</environments>

最外层就是我们的 environments 这个就是配置各种环境(比如:开发,测试,线上...),所以说我们的这个标签有一个 default 属性,就是用来制定我们的具体激活哪个环境的,这里用的是 dev 。然后下面就是具体的环境了,环境的 id 就是我们配置的环境的名称,每一个环境里有且只有两个属性,就是 transactionManagerdataSource 他们必须配置否则会报错。

可以看到 transactionManager 有一个 Type 就是用来指定使用哪个食物管理器,这里它使用了 JDBC 的,其实在Mybatis中只有两种:type=”[JDBC|MANAGED]”

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

  • MANAGED – 这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置为 false 来阻止它默认的关闭行为。例如:

然后我们就很好奇这些 MANAGED 之类的东西在哪有定义,我们是否可以配置自己的书屋管理器比如强大的 Spring的事务管理。

org.apache.ibatis.session.Configuration 在这个类里我们发现了

typeAliasRegistry.registerAlias("JDBC", JdbcTransactionFactory.class);
typeAliasRegistry.registerAlias("MANAGED", ManagedTransactionFactory.class);

typeAliasRegistry.registerAlias("JNDI", JndiDataSourceFactory.class);
typeAliasRegistry.registerAlias("POOLED", PooledDataSourceFactory.class);
typeAliasRegistry.registerAlias("UNPOOLED", UnpooledDataSourceFactory.class);

也就是说他们都是别名而已。那么我们就可以配置自己的类了,我们直接在 type 位置写上我们的事务管理器全类名,或者使用别名机制也可以。具体的对应的类需要什么特性我们直接看看他本来自带的两个类就明白了。

显然下面的配置数据源也是如此,默认的采用了连接池,也就是我们的 sqlSession 对象会被缓存起来不用每次去数据库里获取。

7.databaseIdProvider

MyBatis 可以根据不同的数据库厂商执行不同的语句,这种多厂商的支持是基于映射语句中的 databaseId 属性。 MyBatis 会加载不带 databaseId 属性和带有匹配当前数据库 databaseId 属性的所有语句。 如果同时找到带有 databaseId 和不带 databaseId 的相同语句,则后者会被舍弃。 

我们通过设置属性别名来使其变短 :

<databaseIdProvider type="DB_VENDOR">
  <property name="SQL Server" value="sqlserver"/>
  <property name="DB2" value="db2"/>        
  <property name="Oracle" value="oracle" />
  <property name="MySQL" value="mysql" />
</databaseIdProvider>

然后我们在 mapper 的xml文件中就可以匹配这些数据提供商:

<select id="getEmployeeById" resultType="lwen.entries.Employee" databaseId="mysql">
    select * from employee where id=#{id}
</select>
<select id="getEmployeeById" resultType="lwen.entries.Employee" databaseId="oracle">
    select * from employee where id=#{id}
</select>

那么他会按照数据源来确定当前是哪个数据源,我们需要使用哪个sql语句。这些都是自动进行的,无需我们的干预。

8.mappers

这个就是用来配置我们的 mapper 的 xml 标签了。我们在里面配置 xml 有以下三种方式:

1.使用 mapper 标签

<!--我们的mapper文件的位置-->
<mappers>
    <mapper resource="EmployeeMapper.xml"/>
    <mapper resource="EmployeeMapperInterface.xml"/>
</mappers>

显然这个地方的 mapper 标签还有两个属性 分别就是 resourceuri 就是和上面是一样的。

2.使用包扫描的方式

<package name="lwen"/>

lwen 包下面的xml 映射文件都被加载进去。

3.注解

我们可以使用对应的注解 注解名 就是我们的 sql 语句的动作。 @Select Update 等等

注意以上的标签都是有顺序的,顺序不能随便配置

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这