美文网首页开源工具技巧大数据 爬虫Python AI Sql程序员
自学Mybatis系列(1)——MyBatis的基本构成

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

作者: AceCream佳 | 来源:发表于2017-02-05 19:31 被阅读0次

    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事务的方法中使用它们,然后废弃咯

    相关文章

      网友评论

        本文标题:自学Mybatis系列(1)——MyBatis的基本构成

        本文链接:https://www.haomeiwen.com/subject/otysittx.html