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 ...
随机推荐
- 吴裕雄 python 人工智能——基于Mask_RCNN目标检测(1)
import os import sys import random import math import numpy as np import skimage.io import matplotli ...
- 【PAT甲级】1071 Speech Patterns (25 分)(getline(cin,x))
题意: 输入一行字符串,输出出现过次数最多的由字母和数字组成的字符串以及它出现的次数(对大小写不敏感,输出全部输出小写). AAAAAccepted code: #define HAVE_STRUCT ...
- jQuery中$("input")与$(":input")的区别
$("input")表示获取页面所有的input元素 $(":input")选取表单中所有的input,select 和 button元素
- Windows Server 2012 R2 自动映射公共网络驱动器
1.创建组织单位,在组织单位新建用户或者组 2.新建文件夹(名字无所谓,我这里起名一样方便测试) 3.对文件夹开启共享,设置要共享的用户或者组 4.打开组策略,找到对应的组织单位 5.创建GPO 6. ...
- vmware克隆机无法启动eth0联网问题
cd /etc/sysconfig/network-scrip vi ifcfg-eth0 把eth0修改成eth1,重启网卡就可以了
- :after/::after和:before/::before的异同
相同点 都可以用来表示伪类对象,用来设置对象前的内容:before和::before写法是等效的; :after和::after写法是等效的不同点 :before/:after是Css2的写法,::b ...
- Java面向对象编程 -3.3
综合实战 简单Java类 在以后进行项目开发与设计的过程之中,简单Java类都将作为一个重要的组成部分存在,慢慢接触到正规的项目设计后, 简单Java类无处不再,并且有可能产生一系列的变化. 所谓的简 ...
- PCSearch
1.hinstance:GetModuleHandle(NULL) 2.窗口直角: 方法1:在Oncreate函数中添加以下代码,然而这种方法会导致窗口阴影无效 LONG styleValue = : ...
- ypACM社团年终赛暨实验室选拔赛题解
记得补题,题目两小时半还是挺困难ak的,毕竟我验题也验了几天的时间,题目基本没有锅.题目基本属于简单题 我的三道题都是很基本的题目,希望大家补题 这些题解都是我写的,如果有疑问可以qq问我 所有的核心 ...
- 时隔两天,三星再称GalaxyFold已准备就绪,王自如的脸还好吗?
编辑 | 禾斗 出品 | 于见(mpyujian) 据消息人士透露,三星已经完成对其有缺陷的折叠智能手机进行了重新设计,Galaxy Fold准备适时再度推出,但问题是,作为消费者,我们准备好了吗? ...