请选择 进入手机版 | 继续访问电脑版
设为首页收藏本站

java知识分享-我的java记事本

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1406|回复: 0

Mybatis的基本要素——核心对象

[复制链接]

131

主题

132

帖子

581

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
581
发表于 2019-1-7 22:43:50 | 显示全部楼层 |阅读模式
大家好啊,今天呢来说下Mybatis的核心对象,也就是说基本三要素.
  • 核心接口和类。
  • Mybatis核心配置文件(mybatis-config.xml)
  • SQL映射文件
一、下面首先介绍Mybatis的核心接口和类。




(1) 每个MyBatis的应用程序都以一个SqlSessionFactory对象的实例为核心.
(2) 首先获取SqlSessionFactoryBuilder对象,可以根据XML配置文件或者Configuration类的实例构建该对象。
(3) 然后获取SqlSessionFactory对象,该对象实例可以通过SqlSessionFactoryBuilder对象来获取得。
(4) 有了SqlSessionFactory对象之后,就可以进而获取SqlSession实例,SqlSession对象中完全包含以数据库为背景的所有执行SQL操作的方法。就可以用该实例来直接执行已映射的SQL语句。
二、SqlSessionFactoryBuilder
1、SqlSessionBuider的作用
SqlSessionFactoryBuilder负责构建SqlSessionFactory,并且提供了多个build()方法重载.如图:


通过源码分析,可以发现都是在调用同一签名方法:
build(Rrader reader,String environment,Properties properties)
由于参数environment和properties都可以为null,那么去除重复的,真正的重载方法其实只有如下三种:






通过上述分析,发现配置信息可以以三种形式提供给SqlSessionFactoryBuilder的build()方法,分别是InputStream(字节流),Reader(字符流),Configuration(类),由于字节流与字符流都属于读取配置文件的方式,所以从配置信息的来源就很容易想到构建一个SqlSessionFactory有两种方式:读取XML配置文件构建和编程构造方式。我们一般习惯为采取XML配置文件的方式来构造SqlSessionFactory.
2、SqlSessionFactoryBuider的声明周期和作用域
SqlSessionFactoryBuilder的最大特点是:用过即丢。一旦创建了SqlSessionFactory对象之后,这个类就不再需要存在了,因此SqlSessionFactoryBuilder的最佳范围就是存在于方法体内,也就是局部变量而已。
三、SqlSessionFactory的作用
1、SqlSessionFactory的作用
SqlSessionFactory简单的理解就是创建SqlSession实例的工厂。所有的MyBatis应用都是以SqlSessionFactory实例为中心,SqlSessionFactory的实例可以通过SqlSessionFactoryBuilder对象来获取。有了它以后,顾名思义,就可以通过SqlSession提供的openSession()方法来获取SqlSession实例。如图:


2.SqlSessionFactory的生命周期和作用域
SqlSessionFactory对象一旦创建,就会在整个应用程序过程中始终存在。没有理由去销毁或再创建它,并且在应用程序运行中也不建议多次创建SqlSessionFactory。因此SqlSessionFactory的最佳作用域是Application,即随着应用程序的生命周期一直存在。那么这种"存在于整个应用运行期间,并且只存在一个对象实例"的模式就是所谓的单列模式(指在运行期间有且仅有一个实例):下面举个例子:


通过以上静态类的方式来保证SqlSessionFactory实例只被创建一次,当然,最佳的解决方案是使用依赖注入--Spring框架来管理SqlSessionFactory的单例生命周期。关于整合SSM会在之后写出.
四、SqlSession
1.SqlSession的作用
SqlSession是用于执行持久化操作的对象,类似于JDBC中的Connection。它提供了面向数据库执行SQL命令所需的所有方法,可以通过SqlSession实例直接运行已映射的SQL语句。如图:




2.SqlSession生命周期和作用域
正如其名,SqlSession对应着一次数据库会话。由于数据库会话不是永久的,因此SqlSession的生命周期也不应该是永久的。相反,在每次访问数据库时需要创建它(注意:并不是说在SqlSession里执行一次SQL,是完全可以执行多少次的,但是若是关闭了SqlSession,那么就要重新创建它).创建SqlSession的地方只有一个,那就是SqlSessionFactory对象的openSession方法。
需要注意的是:每个线程都有自己的SqlSession实例,SqlSession实例不能被共享,也不是线程安全的。因此最佳的作用域范围是request作用域或者方法体作用域内。

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|java知识分享 ( 闽ICP备14003021号-4   

GMT+8, 2019-7-16 06:47 , Processed in 0.093426 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表
制砂机    我爱辅助网    煎药机    束丝机    两化融合    深圳seo    约克空调维修    网络公关