[
https://issues.apache.org/jira/browse/CASSANDRA-15345?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Konstantin updated CASSANDRA-15345:
-----------------------------------
Description:
The below example conditional update is wrongly evaluated to True and applied
even though clustering key 'k1' is not present in the table:
CREATE KEYSPACE test_keyspace WITH replication = \{'class': 'SimpleStrategy',
'replication_factor': 1};
CREATE TABLE test_table (id int, k text, version int static, v text, PRIMARY
KEY (id, k));
INSERT INTO test_table(id, version) VALUES (0, 0);
SELECT * FROM test_table;
id | k | version | v
----+------+---------+------
0 | null | 0 | null
(1 rows)
SELECT * FROM test_table WHERE id=0 AND k='k1';
id | k | version | v
----+---+---------+---
(0 rows)
UPDATE test_table SET v='foo', version=1 WHERE id=0 AND k='k1' IF version = 0;
[applied]
-----------
True
SELECT * FROM test_table;
id | k | version | v
----+----+---------+-----
0 | k1 | 1 | foo
(1 rows)
DROP TABLE test_table;
DROP KEYSPACE test_keyspace;
was:
The below example conditional update is wrongly evaluated to True and applied
even though clustering key 'k1' is not present in the table:
{{CREATE KEYSPACE test_keyspace WITH replication = \{'class': 'SimpleStrategy',
'replication_factor': 1};}}
{{CREATE TABLE test_table (id int, k text, version int static, v text, PRIMARY
KEY (id, k));}}
{{INSERT INTO test_table(id, version) VALUES (0, 0);}}
{{SELECT * FROM test_table;}}{{id | k | version | v}}
{{----+------+---------+------}}
{{ 0 | null | 0 | null}}{{(1 rows)}}
{{SELECT * FROM test_table WHERE id=0 AND k='k1';}}{{id | k | version | v}}
{{----+---+---------+---}}{{(0 rows)}}
{{UPDATE test_table SET v='foo', version=1 WHERE id=0 AND k='k1' IF version =
0;}}{{[applied]}}
{{-----------}}
{{ True}}{{SELECT * FROM test_table;}}{{id | k | version | v}}
{{----+----+---------+-----}}
{{ 0 | k1 | 1 | foo}}{{(1 rows)}}
{{DROP TABLE test_table;}}
{{DROP KEYSPACE test_keyspace;}}
> Incorrect result on conditional UPDATE with static and regular conditions
> -------------------------------------------------------------------------
>
> Key: CASSANDRA-15345
> URL: https://issues.apache.org/jira/browse/CASSANDRA-15345
> Project: Cassandra
> Issue Type: Bug
> Components: CQL/Semantics
> Reporter: Konstantin
> Priority: Normal
>
> The below example conditional update is wrongly evaluated to True and applied
> even though clustering key 'k1' is not present in the table:
> CREATE KEYSPACE test_keyspace WITH replication = \{'class': 'SimpleStrategy',
> 'replication_factor': 1};
> CREATE TABLE test_table (id int, k text, version int static, v text, PRIMARY
> KEY (id, k));
> INSERT INTO test_table(id, version) VALUES (0, 0);
> SELECT * FROM test_table;
> id | k | version | v
> ----+------+---------+------
> 0 | null | 0 | null
> (1 rows)
> SELECT * FROM test_table WHERE id=0 AND k='k1';
> id | k | version | v
> ----+---+---------+---
> (0 rows)
> UPDATE test_table SET v='foo', version=1 WHERE id=0 AND k='k1' IF version = 0;
> [applied]
> -----------
> True
> SELECT * FROM test_table;
> id | k | version | v
> ----+----+---------+-----
> 0 | k1 | 1 | foo
> (1 rows)
> DROP TABLE test_table;
> DROP KEYSPACE test_keyspace;
--
This message was sent by Atlassian Jira
(v8.3.4#803005)
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]