mybatis入门-框架原理

时间:2022-11-13 06:44:17
  • mybatis是什么

    在说mybatis原理之前,我们有必要知道,mybatis到底是个什么东西。mybatis是一个持久层的框架。是一个不完全的ORM框架。因为它需要由程序员自己去写sql语句。但是它也可以将对象和数据库表进行输入和输出映射。

    相对于hibernate框架来说,mybatis学习起来更加的简单,学习成本也相对较低。可以让程序员将自己的精力放在sql语句上,由于在mybatis中sql语句单独存放在xml文件中。对于sql语句的修改和优化也比较方便,适用于需求变化较多的项目。基于国内程序员对于hibernate掌握程度参差不齐的现状,所以互联网电商项目多使用mybatis作为持久层框架。以便于提高数据库访问的速度。

  • mybatis的框架原理

    mybatis 框架整体的话,先上一张图吧。然后通过这张图对于mybatis的框架原理进行一下展开。

    mybatis入门-框架原理

    我们知道,持久层的工作就是和数据库打交道,将我们的数据从系统中存入数据库,或者是将数据库中的内容取出。这也是持久层框架干的事情。在mybatis中,mapped statement(底层封装对象)和Executor(执行器),对用户是透明不可见的。也就是说,我们用户不需要知道我们传入的各种参数是如何被mapped statement 进行封装成为一个可以被数据库是别的sql语句的参数的。也不用知道Executor是如何在sqlSession内部通过一系列的执行去操作数据库的。

    我们需要做的是,创建一个sqlSession(链接数据库的会话)的对象,通过这个sqlSession接口提供给程序员的一些方法,传入相应的映射文件(这个文件包含有我们要执行的sql语句)及对应的参数。然后在mybatis内部,将传入的映射文件的内容和传入参数进行解析,然后通过执行器去发送sql语句。再将得到的结果通过底层封装对象进行封装。返回给sqlSession方法的调用方。

    这里需要注意一个地方:sqlSession默认情况下是不会自动提交事务的,所以,在我们跟数据库链接的时候,如果需要提交事务,需要手动的进行提交。而且我们在手动提交sql语句的时候,是需要和数据库建立连接的。那么问题来了,我们的sqlSession这个会话是怎么来的呢?它又是在什么时候和数据库建立了链接呢?

    在我们的mybatis中,有一个会话工厂,它是一个全局只需要一个的工厂。它的作用就是创建sqlsession。和数据库链接的数据源对象就是通过sqlSessionFactory这个工厂进行的创建时,赋值给了sqlSession这个会话对象的。所以一般sqlSessionFactory一般都是配置为单例的。而我们的整个mybatais的所有配置,并不是由sqlSessionFactory去进行读取的,根据单一职责原则,在mybatis中,是由SqlSessionFactoryBuilder去进行读取的,当然,它读取的配置信息是有很多的,将mybatis的运行环境信息读取完成之后,然后创建一个SqlSessionFactory。由于这些读取环境不是mybatis的核心,我们的图上就没有体现。

    那么,这些配置文件写在哪了呢?我们一般写在SqlMapConfig.xml这个文件中。(是mybatis的全局配置文件,名称不固定的)配置了数据源、事务等mybatis运行环境。

     那么,mybatis在运行的时候是怎么执行的呢呢?

    mybatis的执行流程

    首先呢,我们配置mybatis的配置文件,sqlmapConfig.xml这个文件(虽然名称不固定,但是这是约定成俗的写法)。

    然后,通过配置文件,加载mybatis的运行环境,创建SqlSessionFactory的会话工厂(按照单例方式创建,多例也可以,不过浪费资源严重)。

    接下来,通过会话工厂(SqlSessionFactory)去创建会话(SqlSession)。这个接口是线程不安全的,所以建议应用在方法体内。

    剩下的就是,调用sqlSession的方法去操作数据库了。操作完成后,进行下事务的commit()的方法。然后释放资源关闭sqlSession。