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

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

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


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

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

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

35.png

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

36.png


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

 37.png


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

38.png


线程集合内部:


39.png40.png41.png


注意:


//避免内存泄露,要集合清空线程容器
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();
        }
    }
}
目录
相关文章
|
29天前
|
SQL Oracle 关系型数据库
项目中经常看到数据库Connection连接与Session这个你好不知道吗?
项目中经常看到数据库Connection连接与Session这个你好不知道吗?
15 1
解决开启子线程,导致request上下文和session信息丢失问题
解决开启子线程,导致request上下文和session信息丢失问题
837 0
|
2月前
|
Java 关系型数据库 MySQL
【数据库连接,线程,ThreadLocal三者之间的关系】
【数据库连接,线程,ThreadLocal三者之间的关系】
22 0
|
Go
Go channel被关闭时的广播机制,以及遍历未关闭channel时会导致死锁阻塞问题
Go channel被关闭时的广播机制,以及遍历未关闭channel时会导致死锁阻塞问题
123 0
|
SQL 大数据 API
连接操作_连接类型_fullouter | 学习笔记
快速学习连接操作_连接类型_fullouter
76 0
连接操作_连接类型_fullouter | 学习笔记
|
SQL 大数据 开发者
连接操作_连接类型_inner | 学习笔记
快速学习连接操作_连接类型_inner
64 0
连接操作_连接类型_inner | 学习笔记
|
安全 Java
java线程同步 synchronized失效???(理解好是否上锁的是同一个对象,因为同一个对象对应的run( ) 是同一个 )
java线程同步 synchronized失效???(理解好是否上锁的是同一个对象,因为同一个对象对应的run( ) 是同一个 )
352 0
java线程同步 synchronized失效???(理解好是否上锁的是同一个对象,因为同一个对象对应的run( ) 是同一个 )
|
机器学习/深度学习 Java
同一个问题有多个解
https://www.codewars.com/kata/5592e3bd57b64d00f3000047   做这道kata时,有个变量的比较运算符写错了,应该设置为< ,而我设置的 != ,(更正后↓完全正确)   public static long findNb0(long m) { ...
1461 0
|
安全 Java 数据库连接
Hibernate中SessionFactory是线程安全的吗?Session是线程安全的吗(两个线程能够共享同一个Session吗)?
SessionFactory对应Hibernate的一个数据存储的概念,它是线程安全的,可以被多个线程并发访问。SessionFactory一般只会在启动的时候构建。
1339 0
|
数据库
SqlServer 可更新订阅队列读取器代理错误:试图进行的插入或更新已失败
原文:SqlServer 可更新订阅队列读取器代理错误:试图进行的插入或更新已失败 今天发现队列读取器代理不停地尝试启动但总是出错: 其中内容如下: 队列读取器代理在连接“PublicationServer”上的“pubDB”时遇到错误“试图进行的插入或更新已失败, 原因是目标视图或者目标视图所跨越的某一视图指定了 WITH CHECK OPTION, 而该操作的一个或多个结果行又不符合 CHECK OPTION 约束。
1407 0