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 ...
随机推荐
- nginx解决WordPress 上传到服务器后页面404错误的方法
人啊,要说你傻了吧,真是啥事都能碰到: 因为换了nginx,把新做的上传到服务器配置好后,就主页和后台能打开,其他的所有页面,全是404,果真404和502是我最讨厌的数字啊,这让我很怀疑人生啊,怀疑 ...
- ES6-对象的简写方式
var name = 'tom'; var age = 11; //es5定义对象 var obj = { name:name, age ...
- VMware安装EVE
众所周知,EVE是一个非常强大的仿真环境,能给我们学习带来很大的帮助,这里主要简单记录一下安装在VMware下安装EVE的过程. 1.准备: 我安装的VMware是WORKSTATION 12 PRO ...
- JAVA常量池、栈、堆的比较(转载)
今天在学JAVA的数据存储位置的时候,看到了一篇博文感觉不错,特此转载: http://www.cnblogs.com/Eason-S/p/5658230.html JAVA中,有六个不同的地方可以存 ...
- HashMap遍历,取出key和value
HashMap的遍历有两种常用的方法,那就是使用keyset及entryset来进行遍历,在用keySet(key)取value时候,需要key 第一种: Map map = new HashMap( ...
- ubuntu的apt
1. apt edit-sources #编辑apt的源列表( 或者直接写这个命令:vim /etc/apt/sources.list ) 2. apt list #列出包含条件的包(已安装,可 ...
- mysql DATE_FORMAT 函数使用
使用DATE_FORMAT 查询数据库中时间类型显示 SELECT a.name ,a.uuid ,p.assess_price as assessPrice ,p.assess_date as as ...
- C语言:判断t所指字符串中的字母是否由连续递增字母组成。-判断一个输入的任何整数n,是否等于某个连续正整数序列之和。-将一副扑克牌编号为1到54,以某种方式洗牌,这种方式是将这副牌分成两半,然后将他们交叉,并始终保持编号1的牌在最上方。
//判断t所指字符串中的字母是否由连续递增字母组成. #include <stdio.h> #include <string.h> void NONO(); int fun( ...
- centos610无桌面安装tomcat8
1.下载安装包 wget https://www-us.apache.org/dist/tomcat/tomcat-8/v8.5.43/bin/apache-tomcat-8.5.43.tar.gz ...
- Jenkins显示语言切换为中文(最终解决办法)
网上大部分搜索结果都指向同一种方法就是下载Locale插件,但该方法已失效. 新的解决办法: 下载完成之后重启Jenkins生效,会汉化大部分内容,部分设置不会汉化. 注:重启后不生效请检查 1.已安 ...