# 使用数据库连接池 # 创建数据连接池时需要注意的问题(开发实践总结)

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BUG_GUB

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值