Druid的工具类抽取
##具体代码
/********************************************************************************************************
此为Druid的工具类
*******************************************************************************************************/
import com.alibaba.druid.pool.DruidDataSourceFactory;
import javax.sql.DataSource;
import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
public class JDBCUtils_druid {
/************************************************************************************************
静态代码块加载druid的配置文件并注册驱动
************************************************************************************************/
private static DataSource ds ; //ds为连接池对象
static{
try {
Properties pro = new Properties();
pro.load(JDBCUtils_druid.class.getClassLoader().getResourceAsStream("druid.properties"));
ds = DruidDataSourceFactory.createDataSource(pro);
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
/**************************************************************************
获取连接池的连接对象
**************************************************************************/
public static Connection getConnection() throws SQLException {
return ds.getConnection();
}
/***************************************************************************
获取连接池对象
**************************************************************************/
public static DataSource getDataSource(){
return ds;
}
/***************************************************************************
释放资源
***************************************************************************/
public static void close(PreparedStatement pstmt, Connection conn){
close(null,pstmt,conn);
}
public static void close(ResultSet rs , PreparedStatement pstmt, Connection conn){
if(rs != null){
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(pstmt != null){
try {
pstmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(conn != null){
try {
conn.close();//归还连接而不是关闭
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
#druid.properties
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/db3
username=root
password=root
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大等待时间
maxWait=3000
#工具类的使用
public class DruidDemo {
public static void main(String[] args) {
/*****************************************
给数据库中account表添加一条记录
*****************************************/
Connection conn = null;
PreparedStatement pstmt = null;
try {
//获取连接
conn = JDBCUtils.getConnection();
//定义sql
String sql = "insert into account values(null,?,?)";
//获取pstmt对象
pstmt = conn.prepareStatement(sql);
//给?赋值
pstmt.setString(1,"王五");
pstmt.setDouble(2,3000);
//执行sql
int count = pstmt.executeUpdate();
//输出受影响行数
System.out.println(count);
} catch (SQLException e) {
e.printStackTrace();
}finally {
//别忘了释放资源
JDBCUtils.close(pstmt,conn);
}
}
}
#注意事项
-
druid.properties需放在src目录下,方便管理
-
需要导入这两个jar包
-
和c3p0的区别:c3p0不需要手动导入配置,而druid需要导入
来源:CSDN
作者:Best_Lynn
链接:https://blog.csdn.net/Best_Lynn/article/details/104214547