Return-Path: Delivered-To: apmail-db-derby-dev-archive@www.apache.org Received: (qmail 70251 invoked from network); 3 Aug 2009 16:37:34 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (140.211.11.3) by minotaur.apache.org with SMTP; 3 Aug 2009 16:37:34 -0000 Received: (qmail 93918 invoked by uid 500); 3 Aug 2009 16:37:39 -0000 Delivered-To: apmail-db-derby-dev-archive@db.apache.org Received: (qmail 93873 invoked by uid 500); 3 Aug 2009 16:37:39 -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: Delivered-To: mailing list derby-dev@db.apache.org Received: (qmail 93865 invoked by uid 99); 3 Aug 2009 16:37:39 -0000 Received: from nike.apache.org (HELO nike.apache.org) (192.87.106.230) by apache.org (qpsmtpd/0.29) with ESMTP; Mon, 03 Aug 2009 16:37:39 +0000 X-ASF-Spam-Status: No, hits=-2000.0 required=10.0 tests=ALL_TRUSTED X-Spam-Check-By: apache.org Received: from [140.211.11.140] (HELO brutus.apache.org) (140.211.11.140) by apache.org (qpsmtpd/0.29) with ESMTP; Mon, 03 Aug 2009 16:37:36 +0000 Received: from brutus (localhost [127.0.0.1]) by brutus.apache.org (Postfix) with ESMTP id E4F61234C046 for ; Mon, 3 Aug 2009 09:37:14 -0700 (PDT) Message-ID: <846369973.1249317434936.JavaMail.jira@brutus> Date: Mon, 3 Aug 2009 09:37:14 -0700 (PDT) From: "Dag H. Wanvik (JIRA)" To: derby-dev@db.apache.org Subject: [jira] Updated: (DERBY-4330) NullPointerException or assert failure when re-executing PreparedStatement after lock timeout In-Reply-To: <611954760.1249063815076.JavaMail.jira@brutus> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-JIRA-FingerPrint: 30527f35849b9dde25b450d4833f0394 X-Virus-Checked: Checked by ClamAV on apache.org [ https://issues.apache.org/jira/browse/DERBY-4330?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Dag H. Wanvik updated DERBY-4330: --------------------------------- Attachment: repro-union.sql Uploading a new repro, showing another incarnation of this problem, this time with a UNION query, which relies on the SetOpResultSet. That class' openCore has a similar weakness as JoinResultSet's. With sane code I see this: ERROR XJ001: Java exception: 'ASSERT FAILED UnionResultSet already open: org.apache.derby.shared.common.sanity.AssertFailure'. > NullPointerException or assert failure when re-executing PreparedStatement after lock timeout > --------------------------------------------------------------------------------------------- > > Key: DERBY-4330 > URL: https://issues.apache.org/jira/browse/DERBY-4330 > Project: Derby > Issue Type: Bug > Components: SQL > Affects Versions: 10.3.1.4, 10.3.2.1, 10.3.3.0, 10.4.1.3, 10.4.2.0, 10.5.1.1, 10.5.2.0, 10.6.0.0 > Reporter: Knut Anders Hatlen > Attachments: derby-4330a.diff, repro-union.sql, repro.sql > > > I came across a query that failed with a NullPointerException (insane jars) or an assert failure (sane jars) when a PreparedStatement was re-executed after a lock timeout. I'm able to reproduce this on 10.3.1.4 and later. 10.2.2.0 and earlier don't fail. Another fallout from DERBY-827? I've also seen other manifestations of the problem, apparently depending on the actual rows in the tables, including "No current connection" and "The heap container with container id Container(0, 1120) is closed". > Stack trace for the assert failure: > org.apache.derby.shared.common.sanity.AssertFailure: ASSERT FAILED JoinResultSet already open > at org.apache.derby.shared.common.sanity.SanityManager.ASSERT(SanityManager.java:120) > at org.apache.derby.impl.sql.execute.JoinResultSet.openCore(JoinResultSet.java:144) > at org.apache.derby.impl.sql.execute.ProjectRestrictResultSet.openCore(ProjectRestrictResultSet.java:169) > at org.apache.derby.impl.sql.execute.SortResultSet.openCore(SortResultSet.java:248) > at org.apache.derby.impl.sql.execute.ProjectRestrictResultSet.openCore(ProjectRestrictResultSet.java:169) > at org.apache.derby.impl.sql.execute.BasicNoPutResultSetImpl.open(BasicNoPutResultSetImpl.java:248) > at org.apache.derby.impl.sql.GenericPreparedStatement.executeStmt(GenericPreparedStatement.java:416) > at org.apache.derby.impl.sql.GenericPreparedStatement.execute(GenericPreparedStatement.java:297) > at org.apache.derby.impl.jdbc.EmbedStatement.executeStatement(EmbedStatement.java:1235) > at org.apache.derby.impl.jdbc.EmbedPreparedStatement.executeStatement(EmbedPreparedStatement.java:1675) > at org.apache.derby.impl.jdbc.EmbedPreparedStatement.execute(EmbedPreparedStatement.java:1330) -- This message is automatically generated by JIRA. - You can reply to this email to add a comment to the issue online.