首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用DbUtils QueryRunner不会关闭数据库连接

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

Stack Overflow用户
提问于 2016-06-11 12:15:09
回答 1查看 2.8K关注 0票数 1

我使用DbUtils库和QueryRunner类来运行我的查询。从我在DbUtils文档的基础上看,我不需要担心关闭连接。但是,由于某些原因,它不会自动关闭我的连接,甚至不会手动关闭。这是我的代码:

代码语言:javascript
运行
复制
 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);
    }

}

由于im具有定期调用insertSQL方法的线程,过了一段时间后,我会出现“太多连接”错误。我正在使用Tomcat的最新版本,数据库是MYSQL。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-11 14:06:19

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

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

代码语言:javascript
运行
复制
QueryRunner queryRunner = new QueryRunner(dataSource);

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

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

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37763600

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档