10
3000
com.mysql.cj.jdbc.Driver
jdbc:mysql://localhost:3306/mydb?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8
root
123456
5
10
3000
代码实现:
public class c3p0Demo {
public static void main(String[]args) {
try {
//1.创建数据库连接池对象
DataSource ds=new ComboPooledDataSource();
for(int i=0;i<10;i++) {
//2.获取连接对象
Connection conn=ds.getConnection();
//3.打印
System.out.println(i+" "+conn);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
DataSource ds=new ComboPooledDataSource(“otherc3p0”);
for(int i=0;i<10;i++) {
Connection conn=ds.getConnection();
System.out.println(i+" "+conn);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Druid是阿里巴巴开发的目前最好的数据库连接池。具有处理的数据量规模较大,可以进行数据的实时查询展示,交互式查询等特点,目前广泛应用在国内外各个公司。
使用步骤:
-
1.导入官方提供的jar包,定义配置文件:Xxx.properties 配置文件可以是任意名称,可放在任意目录下
-
2.获取数据库连接池对象:通过工厂类来获取 DruidDataSourceFactory
-
3.获取连接:getConnection
创建配置文件:druid.properties
driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mydb?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8
username=root
password=123456
初始化连接数
initialSize=5
最大连接数
maxActive=10
最大等待时间
maxWait=3000
代码验证:
public class DruidDemo1 {
public static void main(String[]args) {
try {
//加载配置文件
Properties pro=new Properties();
InputStream is=druiddemo.class.getClassLoader().getResourceAsStream(“druid.properties”);
pro.load(is);
//获取连接池对象
DataSource ds = DruidDataSourceFactory.createDataSource(pro);
//获取连接
Connection conn=ds.getConnection();
System.out.println(conn);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
定义工具类:
为我方便后期开发,我们一般会选择将一些重复性高的代码提取出来作为工具类
步骤:
-
1.定义一个类:JDBCUtils
-
2.提供静态代码块加载配置文件,初始化连接池对象
-
3.提供方法:获取连接、获取连接池、释放资源...
定义工具类:
public class JDBCUtils {
//定义成员变量DataSource
private static DataSource ds;
//加载静态代码块
static {
try {
//加载配置文件
Properties pro=new Properties();
InputStream is=druiddemo.class.getClassLoader().getResourceAsStream(“druid.properties”);
pro.load(is);
//获取DataSource
ds = DruidDataSourceFactory.createDataSource(pro);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
-
获取连接
-
@return
-
@throws SQLException
*/
public static Connection getConnection() throws SQLException {
return ds.getConnection();
}
/**
-
释放资源
-
@param rs
-
@param stmt
-
@param conn
*/
public static void close(ResultSet rs,PreparedStatement stmt,Connection conn) {
try {
if(rs!=null)rs.close();
if(stmt!=null)stmt.close();
if(conn!=null)conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
-
获取连接池
-
@return
*/
public static DataSource getDataSource() {
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
言尽于此,完结
无论是一个初级的 coder,高级的程序员,还是顶级的系统架构师,应该都有深刻的领会到设计模式的重要性。
- 第一,设计模式能让专业人之间交流方便,如下:
程序员A:这里我用了XXX设计模式
程序员B:那我大致了解你程序的设计思路了
- 第二,易维护
项目经理:今天客户有这样一个需求…
程序员:明白了,这里我使用了XXX设计模式,所以改起来很快
- 第三,设计模式是编程经验的总结
程序员A:B,你怎么想到要这样去构建你的代码
程序员B:在我学习了XXX设计模式之后,好像自然而然就感觉这样写能避免一些问题
- 第四,学习设计模式并不是必须的
程序员A:B,你这段代码使用的是XXX设计模式对吗?
程序员B:不好意思,我没有学习过设计模式,但是我的经验告诉我是这样写的
从设计思想解读开源框架,一步一步到Spring、Spring5、SpringMVC、MyBatis等源码解读,我都已收集整理全套,篇幅有限,这块只是详细的解说了23种设计模式,整理的文件如下图一览无余!
搜集费时费力,能看到此处的都是真爱!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
程序员A:B,你这段代码使用的是XXX设计模式对吗?
程序员B:不好意思,我没有学习过设计模式,但是我的经验告诉我是这样写的
[外链图片转存中…(img-ZpfjYgp4-1713292935016)]
从设计思想解读开源框架,一步一步到Spring、Spring5、SpringMVC、MyBatis等源码解读,我都已收集整理全套,篇幅有限,这块只是详细的解说了23种设计模式,整理的文件如下图一览无余!
[外链图片转存中…(img-hp8toACA-1713292935016)]
搜集费时费力,能看到此处的都是真爱!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!