Cassandra批处理语句 - 执行顺序

时间:2015-05-19 06:04:55

标签: cassandra cql3

我有一个Cassandra的批处理语句,其中包含delete和同一分区键的insert语句,其中delete是第一个语句,insert是第二个语句。批处理语句如何执行这些语句?是否按照相同的顺序添加了语句?

1 个答案:

答案 0 :(得分:7)

不,它不按指定的顺序执行它们。要强制执行特定的执行顺序,可以添加USING TIMESTAMP子句。查看文档以获取更多信息:http://docs.datastax.com/en/cql/3.1/cql/cql_reference/batch_r.html

  

使用时间戳如何维护执行顺序。例如,如果上面的例子(删除并插入相同的分区键),最终结果应该是插入的记录。这可以通过添加时间戳??

是。我将结合上面链接中的示例和DELETE documentation进行演示,然后创建一个名为purchases的简单表,其中包含两个字段:

CREATE TABLE purchases (user text PRIMARY KEY, balance bigint);

接下来,我将使用INSERT和DELETE执行批处理。我将最后执行DELETE,但使用比INSERT更早的时间戳:

BEGIN BATCH
  INSERT INTO purchases (user, balance) VALUES ('user1', -8) USING TIMESTAMP 1432043350384;
  DELETE FROM purchases USING TIMESTAMP 1432043345243 WHERE user='user1';
APPLY BATCH;

当我查询userid时:

aploetz@cqlsh:stackoverflow2> SELECT user, balance, writetime(balance) FROM purchases WHERE user='user1';

 user  | balance | writetime(balance)
-------+---------+--------------------
 user1 |      -8 |      1432043350384

(1 rows)

正如您所看到的,INSERT持续存在,因为它具有最新的时间戳。如果我只是从cqlsh提示符中运行INSERT和DELETE(按此顺序),则查询将不会返回任何内容。