1、问题说明
在写一个 JavaWeb 项目时(使用的 c3p0 数据库连接池),出现了当多次操作页面时出现服务器突然挂掉的情况,详情图片如下:
2、问题原因
在使用DAO设计模式时,写获取数据库连接时多次的创建了数据库连接池。代码如下:
public static Connection getConnection() {
ComboPooledDataSource dataSource = new ComboPooledDataSource("mysql")
Connection conn = null;
try {
// 获取连接(Connection)
conn = dataSource.getConnection();
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
3、解决方法
说明:
在获取数据库连接时是不能重复创建数据库连接池的。
解决方式:
把创建数据库连接池的代码放在获取数据库连接方法的外面,可以作为成员变量,也可以作为静态代码块,也可以作为静态变量。
建议写作静态代码块或静态变量,因为使用其他数据库连接池时,是有差异的。例如使用 DBCP数据库连接池 时是不能作为成员变量创建数据库连接池的。
解决后的代码:
// 创建数据库连接池
private static ComboPooledDataSource dataSource = new ComboPooledDataSource("mysql");
/** * 使用cp30数据库连接池,获取连接数据库 * * @return 返回一个数据库连接 */
public static Connection getConnection() {
Connection conn = null;
try {
// 获取连接(Connection)
conn = dataSource.getConnection();
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
4、补充
DAO设计模式:
Data Access Object 访问数据信息的类和接口,包括了对数据的CRUD(Create、Retrival、Update、 Delete),而不包含任何业务相关的信息。有时也称作:BaseDAO。
即开发时的工具类。
实际开发中的使用:
-
方式一:
实际开发中我们会创建一个DAO类
然后针对不同的表的需求不同我们就定义一个接口,里面封装我们需要的功能。
最后创建一个类实现该接口,并继承于你写的DAO类,这样就可以很方便的对各种表进行操作了。 -
方式二:
创建一个DAO类
然后在其中写一些你经常需要使用的工具方法,并将其设置为静态方法(以后使用就直接使用类名使用)。