自学Mybatis系列(1)——MyBatis的基本构成

JAVA持久层框架——MyBatis学习


写在前面:十分感谢《深入浅出Mybatis技术原理与实战》这本书,大多数地方是书上的话,希望自己能在后面的文章中多写一些自己的理解。而且最重要的是!每次照书无脑敲的时候,都好羞愧啊(害羞脸)。后面一定注意这些问题。最后要感谢点赞、评论以及指正的朋友们,你们是坠吼的!!

传统JDBC与现在的Mybatis

使用JDBC访问数据库的步骤:
1. 使用JDBC编程需要连接数据库,注册驱动和数据库信息。
2. 操作Connection,打开Statement对象
3. 通过Statement执行SQL,返回结果到Result对象
4. 用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()回滚事务。

映射器

映射器的作用:
1. 定义参数类型
2. 描述缓存
3. 描述SQL语句
4. 定义查询结果和实体类的关系

我还是喜欢用xml去实现,因为方便,对,编程的话,能用简单的方式是最好不过的事情了XD。而且我不准备现在纠结在代码上了,本来就是准备简单先介绍的,结果写了一大堆,而且手敲书上代码简直累挺!

生命周期

SqlSessionFactoryBuilder

作用是构造器,我们构建了我们需要的SqlSessionFactory之后,SqlSessionFactoryBuilder他就完成了自己的使命,可以光荣了,所以他的周期存在于方法局部。

SqlSessionFactory

作用是创建SqlSession书上一句话很好:SqlSessionFactory责任是唯一的,即创建SqlSession。那么可知每次程序需要访问数据库,我们就要创建SqlSession,那创建它,需要我们的SqlSessionFactory,那么就代表着它应该存在于应用的整个生命周期始终。正好,理解了之后就可推论:好的!那就用单例模式!Good Job!

SqlSession

SqlSession是一个会话,我们每次创建它使用后,都要关闭它,如果不关闭它,我们数据库的连接资源很快就会被消耗完。系统直接瘫痪,Game Over。所以我们在finally语句块中把它关掉。它存在于一个应用的请求和操作中。

Mapper

作用是发送SQL,返回结果,所以他应该在一个自己所对应的SqlSession事务方法之内,它最大范围和SqlSession是相同的。尽量在一个SqlSession事务的方法中使用它们,然后废弃咯

猜你喜欢

转载自blog.csdn.net/w635614017/article/details/80047581