Return-Path: Delivered-To: apmail-db-derby-dev-archive@www.apache.org Received: (qmail 33554 invoked from network); 7 Oct 2005 07:02:14 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (209.237.227.199) by minotaur.apache.org with SMTP; 7 Oct 2005 07:02:14 -0000 Received: (qmail 38513 invoked by uid 500); 7 Oct 2005 07:02:12 -0000 Delivered-To: apmail-db-derby-dev-archive@db.apache.org Received: (qmail 38485 invoked by uid 500); 7 Oct 2005 07:02:12 -0000 Mailing-List: contact derby-dev-help@db.apache.org; run by ezmlm Precedence: bulk list-help: list-unsubscribe: List-Post: List-Id: Reply-To: "Derby Development" Delivered-To: mailing list derby-dev@db.apache.org Received: (qmail 38472 invoked by uid 99); 7 Oct 2005 07:02:12 -0000 X-ASF-Spam-Status: No, hits=0.0 required=10.0 tests=SPF_FAIL X-Spam-Check-By: apache.org Received: from [192.87.106.226] (HELO ajax.apache.org) (192.87.106.226) by apache.org (qpsmtpd/0.29) with ESMTP; Fri, 07 Oct 2005 00:02:10 -0700 Received: from ajax.apache.org (ajax.apache.org [127.0.0.1]) by ajax.apache.org (Postfix) with ESMTP id 5A94221E for ; Fri, 7 Oct 2005 09:01:49 +0200 (CEST) Message-ID: <1896585971.1128668509368.JavaMail.jira@ajax.apache.org> Date: Fri, 7 Oct 2005 09:01:49 +0200 (CEST) From: "Knut Anders Hatlen (JIRA)" To: derby-dev@db.apache.org Subject: [jira] Closed: (DERBY-557) Client driver gets OutOfMemoryError when re-executing statement without closing ResultSet In-Reply-To: <2115081767.1126193619223.JavaMail.jira@ajax.apache.org> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-Virus-Checked: Checked by ClamAV on apache.org X-Spam-Rating: minotaur.apache.org 1.6.2 0/1000/N [ http://issues.apache.org/jira/browse/DERBY-557?page=all ] Knut Anders Hatlen closed DERBY-557: ------------------------------------ Fix Version: 10.1.1.2 Resolution: Fixed Fixed in trunk (revision 289539) and 10.1 (revision 306950). > Client driver gets OutOfMemoryError when re-executing statement without closing ResultSet > ----------------------------------------------------------------------------------------- > > Key: DERBY-557 > URL: http://issues.apache.org/jira/browse/DERBY-557 > Project: Derby > Type: Bug > Components: Network Client > Versions: 10.1.1.0, 10.1.2.0, 10.2.0.0 > Reporter: Knut Anders Hatlen > Assignee: Knut Anders Hatlen > Priority: Minor > Fix For: 10.1.2.0, 10.2.0.0, 10.1.1.2 > Attachments: DERBY-557.diff, DERBY-557.stat, derbyall_report.txt > > When re-executing a statement without closing the old ResultSet, some of the old ResultSet's resources are not released, and the network client will eventually get an OutOfMemoryError. > Example: > Connection c = DriverManager.getConnection("jdbc:derby://localhost/mydb"); > PreparedStatement ps = c.prepareStatement("select * from sys.systables"); > while (true) { > ResultSet rs = ps.executeQuery(); > } > This code will run for some time and then throw an OutOfMemoryError. Same thing happens with Statement instead of PreparedStatement. If rs.close() is added in the loop, the code works. Explicitly closing the ResultSet should not be necessary according to this quote from the JDBC 3.0 spec: > For Select statements, the statement is complete when the associated result set is closed. The result set is closed as soon as one of the following occurs: > - all of the rows have been retrieved > - the associated Statement object is re-executed > - another Statement object is executed on the same connection -- This message is automatically generated by JIRA. - If you think it was sent incorrectly contact one of the administrators: http://issues.apache.org/jira/secure/Administrators.jspa - For more information on JIRA, see: http://www.atlassian.com/software/jira