JDBC优化及工具类封装
现有问题
ThreadLocal
- 为解决多线程程序的并发问题提供了一种新的思路,使用这个工具类可以很简洁地编写出优美的多线程程序,通常用在多线程中管理共享数据库连接、Session等
- ThreadLocal用于保存某个线程共享变量,原因是Java中,每一个线程对象都有一个ThreadLocalMap<ThreadLocal,Object>,其key就是一个ThreadLocal,而Object即为该线程的共享变量
- 这个map通过ThreadLocal的set和get方法操作,对于同一个static ThreadLocal,不同线程只能从中get,set,remove自己的变量,而不影响其他线程的变量
- 在进行对象跨层传递的时候,使用ThreadLocal可以避免多次传递,打破层次间的约束
- 线程间数据隔离
- 进行事务操作,用于存储线程事务信息
- 数据库连接,Session会话管理
- ThreadLocal对象.get:获取ThreadLocal中当前线程共享变量的值
- ThreadLocal对象.set:设置ThreadLocal中当前线程共享变量的值
- ThreadLocal对象.remove:移除ThreadLocal中当前线程共享变量的值
package com.lotus.senior.utils;
import com.alibaba.druid.pool.DruidDataSourceFactory;
import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
public class JDBCUtilV2 {
private static DataSource dataSource;
private static ThreadLocal<Connection> threadLocal = new ThreadLocal<>();
static {
Properties properties = new Properties();
InputStream is = JDBCUtilV2.class.getClassLoader().getResourceAsStream("db.properties");
try {
properties.load(is);
dataSource = DruidDataSourceFactory.createDataSource(properties);
} catch (Exception e) {
e.printStackTrace();
}
}
public static Connection getConnection() {
try {
Connection connection = threadLocal.get();
if (connection == null) {
connection = dataSource.getConnection();
threadLocal.set(connection);
}
return connection;
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
public st