第06章——Mybatis连接池与事务深入

本文详细介绍了Mybatis中的连接池技术,包括UNPOOLED、POOLED和JNDI三种数据源类型,重点讲解了POOLED连接池的使用及优势。同时,深入探讨了Mybatis中的事务提交方式,解释了如何通过调整openSession参数实现自动提交。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 Mybatis 的连接池技术

在 Mybatis 中也有连接池技术,但是它采用的是自己的连接池技术。
配置的位置:
主配置文件SqlMapConfig.xml中的dataSource标签,type属性就是表示采用何种连接池方式。
<dataSource type=”POOLED”>

1.1 Mybatis 连接池的分类

在 Mybatis 中我们将它的数据源 dataSource 分为以下几类

UNPOOLED 不使用连接池的数据源
采用传统的获取连接的方式,虽然也实现Javax.sql.DataSource接口,但是并没有使用池的思想。
就是不用连接池,每次都要重新获取连接,释放连接。

POOLED 使用连接池的数据源(建议使用)
采用传统的javax.sql.DataSource规范中的连接池,mybatis中有针对规范的实现。
有两个池
在这里插入图片描述

JNDI 使用 JNDI 实现的数据源(了解即可)
采用服务器提供的JNDI技术实现,来获取DataSource对象,不同的服务器所能拿到DataSource是不一样。
注意:如果不是web或者maven的war工程,是不能使用的。
我们学习中一般使用的是tomcat服务器,采用连接池就是dbcp连接池

2 事务深入

2.1 Mybatis 中事务提交方式

Mybatis 中事务的提交方式,本质上就是调用 JDBC 的 setAutoCommit()来实现事务控制。

运行测试代码

@Test
public void testSaveUser() throws Exception {
	User user = new User();
	user.setUsername("mybatis user09");
	//6.执行操作
	int res = userDao.saveUser(user);
	System.out.println(res);
	System.out.println(user.getId());
}

@Before//在测试方法执行之前执行
public void init()throws Exception {
	//1.读取配置文件
	in = Resources.getResourceAsStream("SqlMapConfig.xml");
	//2.创建构建者对象
	SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
	//3.创建 SqlSession 工厂对象
	factory = builder.build(in);
	//4.创建 SqlSession 对象
	session = factory.openSession();
	//5.创建 Dao 的代理对象
	userDao = session.getMapper(IUserDao.class);
}

@After//在测试方法执行完成之后执行
public void destroy() throws Exception{
	//7.提交事务
	session.commit();
	//8.释放资源
	session.close();
	in.close();
}

观察在它在控制台输出的结果:
在这里插入图片描述
这是我们的 Connection 的整个变化过程,通过分析我们能够发现之前的 CUD 操作过程中,我们都要手动进行事务的提交,原因是 setAutoCommit()方法,在执行时它的值被设置为 false 了,所以我们在 CUD 操作中,必须通过 sqlSession.commit()方法来执行提交操作。

2.2 Mybatis 自动提交事务的设置

在这里插入图片描述
查看底层源码可知:openSession的参数默认为false,只要将openSession的参数设置为true即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值