MyBatis的2个核心对象:SqlSessionFactory、SqlSession
SqlSessionFactory
SqlSessionFactory是单个数据库映射关系经过编译后的内存镜像,主要作用是创建SqlSession。
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
// Reader reader = Resources.getResourceAsReader("mybatis-config.xml");
// SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
SqlSessionFactory是线程安全的,一旦被创建,在整个应用程序执行期间都会存在。
创建SqlSessionFactory很消耗数据库资源,如果多次创建同一数据库的SqlSessionFactory,此数据库的资源很容易被耗尽。
尽量使一个数据库只对应一个SqlSessionFactory,构建SqlSessionFactory时,通常使用单例模式。
SqlSession
SqlSession底层封装了JDBC连接,包含了大量的执行sql操作的方法,主要作用是执行持久化操作。
SqlSession是线程不安全的,每一个线程都应该有一个自己的SqlSession实例,并且该实例不能被共享。
SqlSession的使用范围最好是一次请求或一个方法中,不要将SqlSession作为类的成员变量或者放到HttpSession等域中公用,使用完及时关闭。
SqlSession sqlSession=sqlSessionFactory.openSession();
try{
//执行持久化操作
}finally {
sqlSession.close();
}
SqlSession常用的方法
- <T>T selectOne(String statement)
- <T>T selectOne(String statement, Object param)
只能返回0条或1条记录,若返回多条记录,会抛出异常。
- List<E> selectList(String statement)
- List<E> selectList(String statement, Object param)
- List<E> selectList(String statement, Object param, RowBounds rowBounds) //rowBounds用于分页
可以返回0条或多条记录(数量不受限制)。
selectOne、selectList在没有匹配的记录时都是返回null。
- void select(String statement, Object param, ResultHandler handler) //handler指定结果集的处理方式
注意返回值是void,使用handler指定的方式处理结果集,常用于比较复杂的结果集,比如多表查询。
- int insert | update | delete(String statement)
- int insert | update | delete(String statement, Object param)
返回受影响的记录数。
- void commit() //提交事务(本次session期间做的改动)
- void rollback() //回滚事务
- void close() //关闭SqlSession对象
- <T>T getMapper(Class<T> type) //返回Mapper接口的代理对象
该对象关联了SqlSession对象,可通过该对象直接操作数据库,mybatis官方推荐使用Mapper对象操作数据库。参数type是Mapper接口的class对象。
getMapper()的用法可参考:https://www.cnblogs.com/chy18883701161/p/12152695.html
selectList()使用示例
<select id="queryById" parameterType="Integer" resultType="com.chy.pojo.Student">
SELECT * FROM student_tb WHERE id>#{id}
</select>
List<Student> list = sqlSession.selectList("queryById", 5);
返回值类型是写POJO类,不是写List。
mybatis会根据结果集中的记录数来判断,如果只有一条记录,映射为Student对象,如果有多条记录,映射为List<Student>。
分页:只取结果集的一部分记录。
//参数:结果集中的记录的下标,要取的记录数
RowBounds rowBounds = new RowBounds(1, 3);
List<Student> list = sqlSession.selectList("queryById", 5, rowBounds);
只将结果集的第2、3、4条记录取出来,映射到list中。
附 MyBatis常用的工具类
public class MyBatisUtils {
private static SqlSessionFactory sqlSessionFactory;
static {
try {
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
public static SqlSession getSqlSession(){
return sqlSessionFactory.openSession();
}
}
方法声明为static,通过类名直接调用。
MyBatis的2个核心对象:SqlSessionFactory、SqlSession的更多相关文章
- mybatis的两个核心对象SqlSessionFactory和SqlSession对象
mybatis的两个核心对象SqlSessionFactory和SqlSession对象 参见:https://www.cnblogs.com/wxdestiny/p/9743686.html
- Mybatis的基本要素--核心对象
大家好啊,今天呢来说下Mybatis的核心对象,也就是说基本三要素. >核心接口和类. >Mybatis核心配置文件(mybatis-config.xml) >SQL映射文件 一.下 ...
- MyBatis 的基本要素—核心对象
MyBatis 三个基本要素 ➢ 核心接口和类 ➢ MyBatis 核心配置文件(mybatis-config.xml) ➢ SQL 映射文件(mapper.xml) MyBatis 核心接口和类 ...
- 【MyBatis系列5】MyBatis4大核心对象SqlSessionFactoryBuiler,SqlSessionFactory,SqlSession,Mapper
前言 前几篇篇我们简单讲解了MyBatis的简单用法,以及一对一和一对多以及多对多的相关动态sql查询标签的使用,也提到了嵌套查询引发了N+1问题,以及延迟加载相关功能,本篇文章将会从MyBatis底 ...
- MyBatis常用对象SqlSessionFactory和SqlSession介绍和运用
学习框架一个比较好的路径阅读源码.本文介绍的SqlSessionFactory和SqlSession.可以通过了解SqlSessionFactory接口和SqlSession接口以及两个的实现类入手, ...
- MyBatis核心对象
MyBatis 有三个基本要素: 核心接口和类 MyBatis核心配置文件(mybatis-config.xml) SQL映射文件(mapper.xml) 下面首先介绍 MyBatis 的核心接口和类 ...
- MyBatis核心对象之StatementHandler
MyBatis核心对象之StatementHandler StatementHandler ResultHandler ParameterHandler Executor org.apache.iba ...
- Mybatis映射器接口代理对象的方式 运行过程
查询一张表的所有数据. 环境: 使用工具IntelliJ IDEA 2018.2版本. 创建Maven工程不用骨架 1.pom.xml <?xml version="1.0" ...
- mybatis源码解析2---SqlSessionFactoryBuilder、SqlSessionFactory解析
1.先看一个mybatis最简单的Demo String resource = "mybatis-config.xml"; //1.流形式读取mybatis配置文件 InputSt ...
随机推荐
- 初识HttpRunner
一.背景 前段时间接触到HttpRunner自动化测试框架,发现对测试人员代码能力要求极低,用户只需准备好用例脚本即可发起测试,非常方便,故记录一下. 二.安装 运行环境 HttpRunner框架基于 ...
- wordpress 添加友情链接
最近入了wordpress的坑,虽然还没深入,但是好歹弄了点东西了:) 一般网站都有友情链接这个东东吧,看网上说这个有个插件的,叫“Link Manager”,添加完了以后就能添加了,可是我今天去搜的 ...
- C语言传递二维数组
方法一, 形参给出第二维的长度. 例如: #include <stdio.h> ] ) { int i; ; i < n; i++) printf("/nstr[%d] = ...
- template-组件封装
HTML: //:ligit='ligit' 一致 <div id='app'> <template-swiper :ligit='ligit'></template-s ...
- Django ORM 常用的13个方法
介绍一个可以以py脚本方式运行ORM操作的方法: 可在项目内新建个py文件,复制项目内manage.py文件中的以下代码: if __name__ == "__main__": o ...
- HDU 1241 Oil Deposits(经典DFS)
嗯... 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1241 很经典的一道dfs,但是注意每次查到一个@之后,都要把它变成“ * ”,然后继续dfs ...
- [linux] ARCH LINUX 常见问题及实用工具汇总
1.办公 screen-recorder 1)深度linux桌面录制软件(不支持录音),操作简单,可以保存mp4和gif格式 2)命令安装:sudo pacman -S deepin-screen-r ...
- iOS中的主要框架framework
在日常的iOS项目开发中,主要使用的就是Foundation和UIKit这两个框架. (一)Foundation框架 Foundation是对Core Foundation框架的一个封装,使用Foun ...
- PyQt5程序基本结构分析
面向过程版 # 0. 导入需要的包和模块 from PyQt5.Qt import * # 包含了我们常用的QT中的一些类 import sys # 一个内置的模块,系统相关操作 # 代码执行的时候, ...
- Springboot学习:Web开发介绍
简介 使用SpringBoot: 1).创建SpringBoot应用,选中我们需要的模块: 2).SpringBoot已经默认将这些场景配置好了,只需要在配置文件中指定少量配置就可以运行起来 3).自 ...