首页 > 其他 > 详细

如何使得事务使用同一个连接对象Connection呢?

时间:2021-06-27 13:22:35      阅读:13      评论:0      收藏:0      [点我收藏+]

如何使得事务使用同一个连接对象Connection呢?

1,方式一:(如果只是封装到jdbc只一步时,没到dao,使用方法传参的方式):

①,共享同一个connection(先在外面获取,后边就可以作为参数啦):使用传参方式,外面先getConnction获取了一个conction(统一化)

②,然后以参数的形式参入,参数非空就赋值给到里边的this.connection, 空的参数就自己再创建一个Connection。

技术分享图片

①,共享同一个connection(先在外面获取,后边就可以作为参数啦):使用传参方式,外面先getConnction获取了一个conction(统一化)

技术分享图片

 ②,然后以参数的形式参入,参数非空就赋值给到里边的this.connection, 空的参数就自己再创建一个Connection。

 技术分享图片

 

2,方式二:利用线程集合存取(原理,线程集合内部:获取当前线程,利用当前线程获取一个集合~线程集合)~重点

技术分享图片

 

 线程集合内部:

技术分享图片 

技术分享图片

 

 技术分享图片

 

 

注意:

//避免内存泄露,要集合清空线程容器
public void clearThreadLocal(){
this.connection = connThreadLocal.get();
if(Objects.nonNull(this.connection)){
try {
this.connection.close();
this.connection = null;
connThreadLocal.set(null);
connThreadLocal.remove();
} catch (SQLException throwables) {
throwables.printStackTrace();
}
}
}

 

如何使得事务使用同一个连接对象Connection呢?

原文:https://www.cnblogs.com/shan333/p/14939224.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!