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类
           然后在其中写一些你经常需要使用的工具方法,并将其设置为静态方法(以后使用就直接使用类名使用)。