IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 五、SqlSessionFactory 和 SqlSession的介绍(补充) -> 正文阅读

[大数据]五、SqlSessionFactory 和 SqlSession的介绍(补充)

五、SqlSessionFactory 和 SqlSession的介绍(补充)

5.1、SqlSessionFactory

? ????SqlSessionFactory 是一个重量级组件,线程安全的,一般情况下一个数据库对应一个 SqlSessionFactory 对象,所以一般情况下一个应用仅需要一 个SqlSessionFactory 对象;通过 SqlSessionFactory 生成 SqlSession 对象。

//创建SqlSessionFactory对象时默认使用myBatis核心配置文件中的默认环境 
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(input);

? 如果要使用其他的数据库环境则在创建工厂对象时需指定环境:

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(input,test);

5.2、SqlSession

? ????SqlSession 是一个轻量级组件,非线程安全的,该对象通过SqlSessionFactory 对象来获得,SqlSession 对象我们可以看成一个数据库连接对象。该对象中封装了大量操作数据库的方法;由于 SqlSession 是非线程安全的,每次使用时要获得一个 SqlSession 对象,使用结束后关闭该对象;

? ????SqlSessionFactory 有 8 个方法创建 SqlSession 实例。通常来说,当你选择其中一个方 法时,你需要考虑以下几点:

  1. 事务处理:你希望在 session 作用域中使用事务作用域,还是使用自动提交 (auto-commit)?(对很多数据库和/或 JDBC 驱动来说,等同于关闭事务支持)

  2. 数据库连接:你希望 MyBatis 帮你从已配置的数据源获取连接,还是使用自己提供的连接?

  3. 语句执行:你希望 MyBatis 复用 PreparedStatement 和/或批量更新语句(包括插入语句和删除语句)吗?

SqlSession openSession()//默认的,非自动提交事务 SqlSession
openSession(boolean autoCommit)//自动提交事务 SqlSession 
openSession(Connection connection)//使用自己提供的连接(不适用数据源 提供的连接) 
SqlSession openSession(ExecutorType execType)//指定处理器类型

默认的 openSession() 方法没有参数,它会创建具备如下特性的 SqlSession:

  1. 事务作用域将会开启(也就是不自动提交)。

  2. 将由当前环境配置的 DataSource 实例中获取 Connection 对象。

  3. 事务隔离级别将会使用驱动或数据源的默认设置。

  4. 预处理语句不会被复用,也不会批量处理更新。

所以我们一般使用 openSession(ExecutorType.BATCH)这个方法获取 SqlSession 对象。

ExecutorType这个枚举类型定义了三个值:

  1. ExecutorType.SIMPLE:该类型的执行器没有特别的行为。它为每个语句的执行创建一个新的预处理语句。

  2. ExecutorType.REUSE:该类型的执行器会复用预处理语句。

  3. ExecutorType.BATCH:该类型的执行器会批量执行所有更新语句,如果 SELECT在多个更新中间执行,将在必要时将多条更新语句分隔开来,以方便理解。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-22 20:40:57  更:2022-03-22 20:41:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 6:49:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码