使用DbUtils QueryRunner不会关闭数据库连接

时间:2016-06-11 12:15:09

标签: java mysql connection apache-commons-dbutils

我正在使用带有QueryRunner类的DbUtils库来运行我的查询。从我对DbUtils文档的不满意我不需要担心关闭连接。但由于某些原因,它不会自动或甚至手动关闭我的连接。这是我的代码:

 public static DataSource createDataSource() {
    BasicDataSource d = new BasicDataSource();
    d.setDriverClassName(Globals.getInstance().getKonfiguracija().dajPostavku("driver"));
    d.setUsername(Globals.getInstance().getKonfiguracija().dajPostavku("dbUsername"));
    d.setPassword(Globals.getInstance().getKonfiguracija().dajPostavku("dbPassword"));
    d.setUrl(Globals.getInstance().getKonfiguracija().dajPostavku("serverDatabase"));
    return d;
}

public static void insertSQL(String sql)
{
    DataSource dataSource = createDataSource();
    QueryRunner qr = new QueryRunner(dataSource);

    try {
        int inserts = qr.update(sql);
        qr.getDataSource().getConnection().close();

    } catch (SQLException ex) {
        Logger.getLogger(DBController.class.getName()).log(Level.SEVERE, null, ex);
    }

}

由于我有定期调用insertSQL方法的线程,一段时间后我得到“Too many connections”错误。我使用最新版本的Tomcat和数据库是MYSQL。

1 个答案:

答案 0 :(得分:1)

您每次调用DataSource方法时都会创建一个新的insertSQL():这可能是异常的原因。

相反,您应该创建DataSource一次,然后将实例传递给QueryRunner构造函数,例如:

QueryRunner queryRunner = new QueryRunner(dataSource);

使用DataSource,您通常不需要手动关闭连接。

有关更多示例,请参阅https://commons.apache.org/proper/commons-dbutils/examples.html