JAVA持久层框架——MyBatis学习
写在前面:十分感谢《深入浅出Mybatis技术原理与实战》这本书,大多数地方是书上的话,希望自己能在后面的文章中多写一些自己的理解。而且最重要的是!每次照书无脑敲的时候,都好羞愧啊(害羞脸)。后面一定注意这些问题。最后要感谢点赞、评论以及指正的朋友们,你们是坠吼的!!
传统JDBC与现在的Mybatis
使用JDBC访问数据库的步骤:
- 使用JDBC编程需要连接数据库,注册驱动和数据库信息。
- 操作Connection,打开Statement对象
- 通过Statement执行SQL,返回结果到Result对象
- 用Result读取数据,通过代码转化为具体的实体类对象
可见,传统JDBC有很多弊端,总结起来就是工作量大,要花很多精力在复杂的处理上面。
在之后出现了ORM模型,ORM出现的意义在于:数据库数据与实体类之间建立了映射模型。比如说Hibernate就是一个很流行的ORM模型,由于Hibernate对JDBC的封装程度很高,我们不需要编写SQL语言,只需要使用HQL语言就OK。
这专题的文章讲的是MyBatis,而且作者没有接触过Hibernate的编程,所以就不写代码了。
由于Hibernate不足够轻量,所以Mybatis出现了,它灵活、SQL优化、减少了数据的传递。很符合当今时代的主流编程风格
Mybatis入门
暂且不关心Mybaits它的发展历史。我直接来学习它的使用和原理。
MyBatis的包在官网就可以下载到,可以利用官方文档粘代码。
MyBatis的基本构成
- SqlSessionFactoryBuilder:构造器,他根据配置信息和代码生成SqlSessionFactory。
- SqlSessionFactory:工厂接口,依靠工厂来生成SqlSession。
- SqlSession:会话,是一个既可以发送SQL去执行结果,也可以获取Mapper的接口。
- SQL Mapper:由Java接口和XML文件构成的,需要给出对应的SQL和映射规则,它把SQL发送去执行,返回结果。
SqlSessionFactory是MyBatis的核心,它的实例可以通过SqlSessionFactoryBuilder获得。而SqlSessionFactory的任务是创建SqlSession。
有两种方式去创建SqlSessionFactory:1.通过xml文件去配置。2.用代码直接怼。
作者喜欢更简单的方式,只选用xml文件配置的方式!
使用xml方式构建SQLSessionFactory
这里简单举个栗子:
DataSource:获取数据库连接实例的数据源。
TransactionManager:决定事务范围和控制方式的事务管理器。
SQL Mapper:映射器
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>
<!--定义数据库信息-->
<environments default="development">
<environment id="development">
<!--采用jdbc事务管理-->
<transactionManager type="JDBC" />
<!--配置数据库链接信息-->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Drive"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis"/>
<property name="username" value="数据库用户名"/>
<property name="password" value="数据库密码"/> </dataSource>
</environment>
</environments>
<!--定义映射器-->
<mappers>
<mapper resource="你的xxxMapper.xml文件">
</mappers>
</configuration>
解释一下,这里我是照着书手敲的,如果有错误的话请指正,十分感谢。
这里引入了一个xml文件,它包含映射器里面的信息。Mybatis将解析它,生成映射器。
下面是创建SqlSessionFactory的代码
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = null;
sqkSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
这里用SqlSessionFactoryBuilder读取xml文件的内容,去创建SqlSessionFactory对象。
创建SqlSession
SqlSession接口有两个用处:
- 获取映射器,发送给数据库后执行操作,返回结果
- 可以通过update、insert、select、delete等方法,操作Xml中配置好的SQL,也支持事务,也就是通过commit()提交事务和rollback()回滚事务。
映射器
映射器的作用:
- 定义参数类型
- 描述缓存
- 描述SQL语句
- 定义查询结果和实体类的关系
我还是喜欢用xml去实现,因为方便,对,编程的话,能用简单的方式是最好不过的事情了XD。而且我不准备现在纠结在代码上了,本来就是准备简单先介绍的,结果写了一大堆,而且手敲书上代码简直累挺!
生命周期
SqlSessionFactoryBuilder
作用是构造器,我们构建了我们需要的SqlSessionFactory之后,SqlSessionFactoryBuilder他就完成了自己的使命,可以光荣了,所以他的周期存在于方法局部。
SqlSessionFactory
作用是创建SqlSession书上一句话很好:SqlSessionFactory责任是唯一的,即创建SqlSession。那么可知每次程序需要访问数据库,我们就要创建SqlSession,那创建它,需要我们的SqlSessionFactory,那么就代表着它应该存在于应用的整个生命周期始终。正好,理解了之后就可推论:好的!那就用单例模式!Good Job!
SqlSession
SqlSession是一个会话,我们每次创建它使用后,都要关闭它,如果不关闭它,我们数据库的连接资源很快就会被消耗完。系统直接瘫痪,Game Over。所以我们在finally语句块中把它关掉。它存在于一个应用的请求和操作中。
Mapper
作用是发送SQL,返回结果,所以他应该在一个自己所对应的SqlSession事务方法之内,它最大范围和SqlSession是相同的。尽量在一个SqlSession事务的方法中使用它们,然后废弃咯