Mybatis框架学习(一)——核心组件

Mybatis的核心组件

Mybatis的核心组件分为4个部分:
SqlSessionFactoryBuilder(构造器): 它会根据配置或者代码来生成SqlSessionFactory,采用的是分步构建的Builder模式。
SqlSessionFactory(工厂接口): 依靠它来生成SqlSession,使用的是工厂模式。
SqlSession(会话): 一个既可以发送sql执行结果,也可以获取Mapper的接口。在现有的技术中,一般我们会让其在业务代码逻辑代码中“消失”,而使用的是Mybatis提供的Sql Mapper 接口编程技术,它能提高代码的可读性和可维护性。
Sql Mapper(映射器): Mybatis新设计存在的组件,它由一个java接口和XML文件或者注解组成,需要给出对应的SQL和映射规则,它负责发送SQL去执行。


配置或代码
可发送Sql
SqlSessionFactoryBuilder
SqlSessionFactory
SqlSession
Sql Mapper
数据库

注意 无论是映射器还是SqlSession都可以发送Sql到数据库中执行。

Mybatis组件的生命周期

生命周期是组件的重要问题,尤其是在多线程的环境中,比如互联网应用、socket请求等,而Mybatis也常用于多线程的环境中,错误使用会造成严重的多线程并发问题。所谓生命周期就是每一个对象应该存活的时间,比如一些对象一次用完后就要关闭,使它们被JAVA虚拟机销毁,以避免继续占用资源,所以我们会根据每一个组件的作用去确定其生命周期。

  • SqlSessionFactoryBuilder
    SqlSessionFactoryBuilder的作用在于创建SqlSessionFactory,创建成功后,SqlSessionFactoryBuilder就失去了作用,所以它只能存在于创建SqlSessionFactory的方法中,而不能让其长期存在。
  • SqlSessionFactory
    SqlSessionFactory可以被认为是一个数据库连接池,它的作用是创建SqlSession接口对象。因为Mybatis的本质就是Java对数据库的操作,所以SqlSessionFactory的生命周期存在于整个Mybatis的应用中,所以一旦创建SqlSessionFactory,就要长期保存它,直至不再使用Mybatis应用,所以可以认为SqlSessionFactory的生命周期就等同于Mybatis的应用周期。
    由于SqlSessionFactory是一个对数据库的连接池,所以它占据着数据库的连接资源。如果创建多个SqlSessionFactory,那么就存在多个数据库连接池,这样不利于对数据库资源的控制,也会导致数据库连接资源被消耗光,出现系统宕机的情况,所以尽量避免发生这样的情况。因此在一般的应用中往往将SqlSessionFactory作为一个单例,让它在应用中被共享。
  • SqlSession
    SqlSession相当于一个数据库连接对象(Connection对象),你可以在一个事务里面执行多条Sql,然后通过它的CommitRollback等方法,提交或者回滚事务。所以它应该存活在一个业务请求中,处理完整个请求后,应该关闭这条连接,将它归还给SqlSessionFactory,否则数据库资源会很快被消耗完,系统就会瘫痪,所以用 try…catch…finally… 语句来保证其正确关闭。
  • Mapper
    Mapper是一个接口,它由SqlSession所创建,所以它的最大生命周期最多和SqlSession保持一致,由于SqlSession的关闭,它的数据库连接资源也会消失。所以它的生命周期是应该 <= SqlSession 的生命周期。Mapper 代表的是一个请求中的业务处理,所以它应该在一个请求中,一旦完成了相关的业务,就应该废弃它。

. - . - .
. - . - .
. - . - .
SqlSessionFactory
SqlSession 1
SqlSession 2
SqlSession 3
Mapper 1
Mapper 2
Mapper 3
SqlSessionFactory通过

SqlSessionFactoryBuilder

创建,在一个Mybatis中

以单例存在
SqlSession存在于一个请求的过程中,

请求结束后需要关闭它
Mapper代表处理请求中的一个

业务处理步骤,随着SqlSession的

关闭而废弃它
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章