You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cassandra.apache.org by "Sylvain Lebresne (JIRA)" <ji...@apache.org> on 2014/01/27 18:49:40 UTC

[jira] [Resolved] (CASSANDRA-6607) Unable to prepare statement with batch and delete from collection

     [ https://issues.apache.org/jira/browse/CASSANDRA-6607?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Sylvain Lebresne resolved CASSANDRA-6607.
-----------------------------------------

       Resolution: Fixed
    Fix Version/s: 1.2.14

Oh, right, that's definitively an oversight. Fix committed to 1.2. Thanks for the report.

> Unable to prepare statement with batch and delete from collection
> -----------------------------------------------------------------
>
>                 Key: CASSANDRA-6607
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-6607
>             Project: Cassandra
>          Issue Type: Bug
>          Components: Core
>            Reporter: Jan Chochol
>            Assignee: Sylvain Lebresne
>            Priority: Minor
>             Fix For: 1.2.14
>
>
> It is not possible to prepare statement with batch containing delete operation on one item of collection, e.g.:
> {noformat}
> BEGIN BATCH
> DELETE colection[?] FROM table WHERE key = ?;
> APPLY BATCH
> {noformat}
> Result of preparing such statement is:
> {noformat}
> java.lang.ArrayStoreException: org.apache.cassandra.cql3.ColumnSpecification
> {noformat}
> With stacktrace:
> {noformat}
> ERROR 16:26:36,816 Unexpected exception during request
> java.lang.ArrayStoreException: org.apache.cassandra.cql3.ColumnSpecification
> 	at org.apache.cassandra.cql3.AbstractMarker.collectMarkerSpecification(AbstractMarker.java:40)
> 	at org.apache.cassandra.cql3.Operation.collectMarkerSpecification(Operation.java:75)
> 	at org.apache.cassandra.cql3.statements.DeleteStatement.prepare(DeleteStatement.java:160)
> 	at org.apache.cassandra.cql3.statements.BatchStatement.prepare(BatchStatement.java:125)
> 	at org.apache.cassandra.cql3.statements.BatchStatement.prepare(BatchStatement.java:133)
> 	at org.apache.cassandra.cql3.QueryProcessor.getStatement(QueryProcessor.java:273)
> 	at org.apache.cassandra.cql3.QueryProcessor.prepare(QueryProcessor.java:201)
> 	at org.apache.cassandra.transport.messages.PrepareMessage.execute(PrepareMessage.java:77)
> 	at org.apache.cassandra.transport.Message$Dispatcher.messageReceived(Message.java:287)
> 	at org.jboss.netty.channel.SimpleChannelUpstreamHandler.handleUpstream(SimpleChannelUpstreamHandler.java:70)
> 	at org.jboss.netty.channel.DefaultChannelPipeline.sendUpstream(DefaultChannelPipeline.java:564)
> 	at org.jboss.netty.channel.DefaultChannelPipeline$DefaultChannelHandlerContext.sendUpstream(DefaultChannelPipeline.java:791)
> 	at org.jboss.netty.handler.execution.ChannelUpstreamEventRunnable.doRun(ChannelUpstreamEventRunnable.java:43)
> 	at org.jboss.netty.handler.execution.ChannelEventRunnable.run(ChannelEventRunnable.java:67)
> 	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
> 	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
> 	at java.lang.Thread.run(Thread.java:724)
> {noformat}
> This fix seems to help:
> {noformat}
> diff --git a/src/java/org/apache/cassandra/cql3/statements/BatchStatement.java b/src/java/org/apache/cassandra/cql3/statements/BatchStatement.java
> index f93eb63..74c0a45 100644
> --- a/src/java/org/apache/cassandra/cql3/statements/BatchStatement.java
> +++ b/src/java/org/apache/cassandra/cql3/statements/BatchStatement.java
> @@ -129,7 +129,7 @@ public class BatchStatement extends ModificationStatement
>  
>      public ParsedStatement.Prepared prepare() throws InvalidRequestException
>      {
> -        CFDefinition.Name[] boundNames = new CFDefinition.Name[getBoundsTerms()];
> +        ColumnSpecification[] boundNames = new ColumnSpecification[getBoundsTerms()];
>          return prepare(boundNames);
>      }
> {noformat}
> It is probably corrected in Cassandra 2.0 by commit {{e431fb722f80d8957a0a7fd2ecf80333e9275c53}} (CASSANDRA-5443).
> We  are facing this issue with Cassandra version 1.2.11.
> Would it be possible to fix this issue in branch 1.2?



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)