MyBatis中连接的获取过程

开发工具与关键技术:MyEclipse、MyBatis
作者:LJR
撰写时间:2020年 12 月 04 日

在学习Mybatis的时候,可能我们会遇到很多的难点,在做数据库连接的连接池的时候,做一点点的总结。
Mybatis中连接的获取过程分析
当我们需要创建 SqlSession 对象并需要执行 SQL 语句时,这时候 MyBatis 才会去调用 dataSource 对象 来创建java.sql.Connection对象。
也就是说,java.sql.Connection对象的创建一直延迟到执行SQL语句 的时候。

@Test 
public void testSql() throws Exception { 
	InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");  
	SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); 
	SqlSession sqlSession  = factory.openSession();  
	List<User> list = sqlSession.selectList("findUserById",41);  
	System.out.println(list.size()); 
} 

只有当第 4句sqlSession.selectList(“findUserById”),才会触发MyBatis 在底层执行下面这个方 法来创建 java.sql.Connection 对象。
如何证明它的加载过程呢?
我们可以通过断点调试,在 PooledDataSource 中找到如下 popConnection()方法,
如下所示 :
在这里插入图片描述

下面是连接获取的源代码:
在这里插入图片描述

最后我们可以发现,真正连接打开的时间点,只是在我们执行SQL语句时,才会进行。其实这样做我们也可以 进一步发现,数据库连接是我们最为宝贵的资源,只有在要用到的时候,才去获取并打开连接,当我们用完了就再 立即将数据库连接归还到连接池中。
这样子我们的Mybatis中连接的获取过程就完成了。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值