ResultSet
を閉じると自動的に閉じられるようConnection
です。しかし、を返して別のメソッドで使用したいのですが、どこでResultSet
閉じるかわかりません。Connection
PreparedStatement
public ResultSet executeQuery(String sql, String[] getValue)
{
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try
{
conn = getConn();
pstmt = conn.prepareStatement(sql);
if (getValue != null)
{
for (int i = 0; i < getValue.length; i++)
{
pstmt.setString(i + 1, getValue[i]);
}
}
rs = pstmt.executeQuery();
} catch (Exception e)
{
e.printStackTrace();
closeAll(conn, pstmt, rs);
}
return rs;
}
キャッチブロックに移動closeAll(conn, pstmt, null);
したのは、最後にブロックに入れると、rs
戻る直前に失くしてしまうことがわかったためです。これで、を閉じたいときに、とを閉じるrs
ことができません。解決策はありますか?conn
pstmt