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 ...
随机推荐
- Visual Studio调试Tersseract
在Visual Studio中打开Tesseract项目,然后项目-->属性-->调试-->命令变量: 比如在debug目录下有一张 test.jpg的图片,里面有中文需要识别,命令 ...
- 文本编辑器EditPlus的安装
- MySQL:ALTER COLUMN、MODIFY COLUMN 和 CHANGE COLUMN
ALTER COLUMN.MODIFY COLUMN 和 CHANGE COLUMN 语句修改列: ALTER COLUMN:改变.删除列的默认值(备注:列的默认值存储在 .frm 文件中). 这个语 ...
- 消息队列(四)--- RocketMQ-消息发送
概述 RocketMQ 发送普通消息有三种 可靠同步发送 可靠异步发送 单向(oneway)发送 :只管发送,直接返回,不等待消息服务器的结果,也不注册回调函数,简单地说,就是只管发,不管信息是否发送 ...
- AtCoDeer and Election Report
问题 G: AtCoDeer and Election Report 时间限制: 1 Sec 内存限制: 128 MB[提交] [状态] 题目描述 AtCoDeer the deer is seei ...
- crawlSpider全站爬取 分布式
# 如何提升scrapy爬取数据的效率? 推荐: 单线程加异步协程 增加并发: 默认scrapy开启的并发线程为32个,可以适当进行增加.在settings.py中修改 CONCURRENT_REQU ...
- iOS 开发之 SDWebImage 底层实现原理分析
SDWebImage 是一个比较流行的用于网络图片缓存的第三方类库.这个类库提供了一个支持缓存的图片下载器.为了方便操作者调用,它提供了很多 UI 组件的类别,例如:UIImageView.UIBut ...
- Ansible自动化搭建及工具集和常见模块、命令详情(重点)
一.ansible介绍 1.ansible简介 官方的title是“Ansible is Simple IT Automation”——简单的自动化IT工具. Ansible跟其他IT自动化技术的区别 ...
- windows 配置hadoop环境
在idea运行spark程序的时候报错:java.io.IOException: Could not locate executable null\bin\winutils.exe in the Ha ...
- 在Visual Studio 2017中,.NET(C#)通过Oracle.ManagedDataAccess来连接Oracle数据库
C#如何通过Oracle.ManagedDataAccess来连接Oracle数据库 1.先创建一个项目,鼠标右击项目中的引用,再点击管理NuGet程序包(也可以先下载dll文件,再选添加引用),在搜 ...