使用 DbUtils QueryRunner 不会关闭数据库连接
Using DbUtils QueryRunner doesnt close database connections
我将 DbUtils 库与 QueryRunner class 一起用于 运行 我的查询。根据我对 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。
您在每次调用 insertSQL()
方法时都创建了一个新的 DataSource
:这可能是异常的原因。
相反,您应该创建 DataSource
一次,然后将实例传递给 QueryRunner
构造函数,例如:
QueryRunner queryRunner = new QueryRunner(dataSource);
使用DataSource
,您通常不需要手动关闭连接。
有关更多示例,请参阅 https://commons.apache.org/proper/commons-dbutils/examples.html。
我将 DbUtils 库与 QueryRunner class 一起用于 运行 我的查询。根据我对 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。
您在每次调用 insertSQL()
方法时都创建了一个新的 DataSource
:这可能是异常的原因。
相反,您应该创建 DataSource
一次,然后将实例传递给 QueryRunner
构造函数,例如:
QueryRunner queryRunner = new QueryRunner(dataSource);
使用DataSource
,您通常不需要手动关闭连接。
有关更多示例,请参阅 https://commons.apache.org/proper/commons-dbutils/examples.html。