0

我有一个 DAO 类,它有下面的方法。我在事务管理器中称它为这个。当我在没有“conn.commit()”行的情况下运行它时 - 它会引发超时异常,但是当我用这个运行它时 - 没关系。有什么问题?据我所知,如果您不修改数据库,则无需提交?

    @Override
    public List<String> getLinks(int id) throws SQLException {
        List<String> list = new ArrayList<>();
        Connection conn = factory.newConnection();
        Statement statement = null;
        ResultSet rs = null;
        try {
            String expression = "select link from users.links where id=" + id + " order by id_link desc";
            statement = conn.createStatement();
            rs = statement.executeQuery(expression);
            while (rs.next()) {
                list.add(rs.getString("link"));
            }
            // !!!!!!!!!!!!! without next line method throw TimeoutException
            conn.commit(); // <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
            // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
            return list;
        } catch (SQLException e) {
            rollBackQuietly(conn);
            e.printStackTrace();
        } finally {
            closeQuaitly(rs);
            closeQuaitly(statement);
            closeQuaitly(conn);
        }
        return null;
    }
4

1 回答 1

0

看到commit()调用是抛出异常的行之后,这个问题必须在重复调用此方法之后出现(在您的问题中包含有用的信息)。这使我相信您的 Connection 工厂正在重用 Connections,并且它正在分发“陈旧”的 Connections(已存在太久且不再可用的 Connections)。如果这一切都是真的,那么您需要让您的工厂更好地管理连接。如果它是一个合理构建的连接池,它可能具有一些您需要启用的功能,例如“空闲时测试”或“获取时测试”。

于 2014-10-12T12:57:35.857 回答