入“坑”mybatis后如何挣脱?
既然已经入”坑“mybatis了,你竟然还想着挣脱,我是不会让你挣脱的~
当然我有一个算是挣脱的办法。那就是把它学会、理解透。这样我们也就不用在坑里一直徘徊,也算得上是一种挣脱吧!
我在上一遍文章(mybatis正确入“坑”方式)中对创建一个mybatis项目过程中有过的简单的解释,这篇文章对增加mybatis生命周期和更加详细的配置的说明和解释以及在配置的可能会遇到的关键问题。
一、mybatis作用域与生命周期
如下图是mybatis简易的生命周期图。首先mybatis通过IO流的方式获取配置文件mybatis.config.xml的信息,然后利用SqlSessionFactoryBuilder创建SqlSessionFactory,而SqlSessionFactory是在一个mybatis中是以单例形式存在的,接着利用SqlSessionFactory生产SqlSession,接着利用SqlSession调用SQL Mapper去处理具体的业务。
SqlSessionFactoryBuilder
SqlSessionFactoryBuilder的作用就是用来创建SqlSessionFactory的,所以创建完成SqlSessionFactory后便可以将其丢弃,所以SqlSessionFactoryBuilder的作用域最好就是在局部方法中。当需要它是可以再次重用,但是不要一直保留。
SqlSessionFactory
SqlSessionFactory被创建成功后,你应该保证它在运行期间一直存在,因为每一个业务都需要同样的SqlSessionFactory去创建SqlSession。因此 SqlSessionFactory 的最佳作用域是应用作用域。也就是要使SqlSessionFactory在每一个mybatis中都是以单例形式存在的。
SqlSession
SqlSession 的实例不是线程安全的,是不能被共享的,所以作用域最好是在局部方法中。同时对于每一次请求SqlSession,返回一个响应后,应该及时关闭它。
Mapper映射器实例
Mapper映射器接口的实例是从 SqlSession 中获得的,最好将映射器放在方法作用域内,这样可以更好的管理。Mapper代表的是一个具体的业务处理,所以当处理完该业务时就可以丢弃。Mapper是随着SqlSession的关闭而消失废弃的。
二、mybatis关键配置详解
properties属性
properties标签:可以动态配置属性。
可以全部在外部进行配置,如下:
<properties resource="db.properties" />
也可以在通过property标签一部分在外部进行内部配置另一部分在内部进行配置(如下),增加配置的灵活性。
<properties resource="db.properties"><property name="username" value="root"/><property name="password" value="123456"/>
</properties>
当外部的db.properties文件进行配置之后,在property标签中又配置一遍后会使用哪一个配置呢?
这就需要考虑优先级的问题,通过方法参数传递的属性具有最高优先级,resource/url 属性中指定的配置文件次之,最低优先级的则是 properties 元素中指定的属性。这里我们的db.properties文件时通过resource指定的,所以优先级大于properties元素指定的属性。所以优先使用外部的db.properties文件中的配置。
typeAliases类型别名
配置Mapper.xml的类型别名可以降低书写冗余的全限定类名。通过对实体类别名的配置,简化开发人员的书写的代码量。比如需要书写com.wkx.pojo.User的全限定类名,在配置别名后便可以仅仅书写user。
那么如何去配置类型别名呢?
第一种:通过typeAlias的标签去配置,这样需要对每一个实体类进行分别配置。type属性中为实体类的路径,alias属性为别名名称。
<!--配置别名-->
<typeAliases><typeAlias type="com.wkx.pojo.User" alias="user"/>
</typeAliases>
第二种:通过package标签属性去配置,name属性为实体类所在的包路径。
在无注解的情况下,使用 Bean 的首字母小写的非限定类名来作为它的别名,比如com.wkx.pojo.User的别名便是user
<!--配置别名-->
<typeAliases><package name="com.wkx.pojo"/>
</typeAliases>
在有注解的情况下,使用注释的别名进行配置。
@Alias("wkx")
public class User {......
}
使用注解后便可以通过注解的内容进行类型配置
<mapper namespace="com.wkx.dao.UserMapper"><select id="getUser" resultType="wkx">select * from user</select>
</mapper>
下面列出关于Java类型内建的类型别名,这里只列出一部分,其他的类型的别名可以依次类推。比如别名为_double,映射类型为double;别名为double,对应映射类型为Double。
别名 | 映射的类型 |
---|---|
_int | int |
_integer | int |
int | Integer |
integer | Integer |
map | Map |
hashMap | HashMap |
environments环境配置
用于配置数据的环境。可配置多个数据库环境,但是SqlSessionFactory只能选择一个去使用。如下:
<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><environment id="test"><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>
可以在不同的环境下切换不同的数据环境,只需要修改environments标签中的default属性对应不同环境下的id属性,比如development和test不同的环境。
事务管理器(transactionManager)
在mybatis中有两种不同的事务管理器,即type="JDBC"或者type=“MANAGED”
JDBC的事务类型是直接使用了 JDBC 的提交和回滚设施,它依赖从数据源获得的连接来管理事务作用域。
MANAGED的事务类型配置几乎没有做什么,从不提交或回滚一个连接,而是让容器来管理事务的整个生命周期。
数据源(dataSource)
主要有三种数据源类型,即type="[UNPOOLED|POOLED|JNDI]"。
UNPOOLED的数据源类型是不使用连接池,每次请求时都会打开和关闭连接,显然这样的连接数据源类型效率不高。
POOLED的数据源类型是使用连接池的概念,每次请求可以直接从“池”子里拿出活跃的连接,避免了重复的创建连接,提高效率。
JNDI的数据源类型实现是为了能让在 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的数据源引用。
mappers映射器
定义映射的路径,告诉mybatis去哪里找对应的语句。我们可以是使用类路径的资源引用方式(推荐使用):
<!-- 使用相对于类路径的资源引用 -->
<mappers><mapper resource="com/wkx/dao/AuthorMapper.xml"/>
</mappers>
可以通过使用完全限定资源定位符(URL)的方式(方式二):
<!-- 使用完全限定资源定位符(URL) -->
<mappers><mapper url="file:///E:/UserMapper.xml"/>
</mappers>
可以通过映射器接口实现类的完全限定类名的方式(方式三):
<!-- 使用映射器接口实现类的完全限定类名 -->
<mappers><mapper class="com.wkx.dao.UserMapper"/>
</mappers>
可以包的形式将映射器接口全部注册为映射器的方式(方式四):
<mappers><package name="com.wkx.dao"/>
</mappers>
注意:方式三和方式四使用需要具备两个条件,一个是接口和Mapper的名称一致,比如UserMapper.java接口和UserMapper.xml必须都是UserMapper,也就是一致的。另一个是接口和Mapper的包名一致。
入“坑”mybatis后如何挣脱?相关推荐
- 【随笔】入坑半年后对嵌入式的一点认识
我们自动化系是一个就业非常轻松的专业,可以让我们从事的行业非常丰富: 电子/电气工程师.电气工程师/技术员.自动化工程师.电气工程师.自动控制工程师/技术员.研发工程师.电子工程师/技术员.软件工程师 ...
- 支持所有库的python手机编程-入坑 Python 后强烈推荐的一套工具库
让我们创建一个新的项目目录: mkdir best_practices cd best_practices Pipx是一个方便的实用程序,允许快速安装python命令行工具.我们将用它来安装 pipe ...
- 日增百万级文件的实时采集的入坑出坑自强之路
1.目录 文章目录 1.目录 2.写在前面的话 填坑不容易,入坑需谨慎!!! 3.功能简介 3.1模块简介 4.采集模块功能实现 4.1文件下载,解析,写入kafka 4.2 数据采集 2.写在前面的 ...
- 率土之滨服务器维护2月19日,率土之滨连发两封致歉信后,资深月卡党的我决定重新入坑...
原标题:率土之滨连发两封致歉信后,资深月卡党的我决定重新入坑 这段时间率土之滨发生了一件大事闹得沸沸扬扬,于是我这位曾经的老玩家也在吃瓜一线,问了一些过去的游戏好友,原来是上线了一个宝物系统引起了众多 ...
- jdbc快速入坑(二)
这里只是对jdbc及进行简单的入门与使用,详细的教程戳这里,因为咱也是学人家的.OK,直接开整,项目代码地址:https://gitee.com/fluffycatkin/yyx-study-my ...
- Camunda BPM工作流引擎入坑指南(一)
Camunda BPM工作流引擎入坑指南 欢迎使用Camunda BPM工作流 入坑说明书 入坑准备工作 BPMN2.0基础 Camunda实战 Camunda BPM Activiti对比 功能快捷 ...
- 开发工具篇第九讲:菜鸟入坑指南
摘要:本文是开发工具篇第九讲:菜鸟入坑指南.针对新人上手慢的问题,写了这篇入坑指南,方便自己回顾,总结.本文分为四个部分,分别为jenkins使用技巧:常用软件操作命令:开发手册:调试手册.主要材料来 ...
- 发布开源框架到CocoaPods入坑指南
个人原文博客地址: 发布开源框架到CocoaPods入坑指南 在开发过程中一定会用到一些第三方框架, 只要安装了CocoaPods, 然后通过pod install命令, 就可以集成框架到项目中了 可 ...
- 魔兽世界多玩服务器位置,选择服务器也有大学问?新手入坑《魔兽世界》该在哪里“扎根”...
<魔兽世界:暗影国度>开服至今已经五个多月了,圈内圈外都在讨论新版本的话题,不少萌新与老玩家都选择了在这个版本中加入探索暗影界的行列.但面对茫茫多的区服,许多玩家都犯起了"选择困 ...
最新文章
- 数学图形(1.32) 鸡蛋
- 100亿数据1万属性数据架构设计
- 多个工作表同时处理+选中不连续的单元格和工作表
- jQuery对HTML进行添加元素
- 【最新】docker 安装elasticsearch + kibana步骤【第二篇_kibana】
- 前端学习(612):js的三种书写位置
- linux内核创建字符节点,Tiny6410学习ing—(四)、嵌入式Linux内核驱动进阶—(7)、高级字符设备驱动(自动创建节点)—#931...
- cocos2d-x3.6 连连看随机地图实现
- keep dark about sth
- 苹果Mac备份应用推荐:Get Backup Pro
- 详解NRF24L01无线收发模块
- python cpk 计算
- 一、Webservice的概念和原理
- WinForm——MDI窗体
- office 2007 word空格消失的问题
- 用c语言编写匀速直线运动,匀速直线运动知识点总结
- C语言中文字符索引,C语言关键字中英文对照索引
- 连接MySql报错【ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)】
- 同时打开多个远程桌面连
- SSL_2325【最小转弯问题】