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)
1 回答
不,它不按指定的顺序执行它们 . 要强制执行特定的执行顺序,可以添加
USING TIMESTAMP
子句 . 查看文档以获取更多信息:http://docs.datastax.com/en/cql/3.1/cql/cql_reference/batch_r.html是 . 我将结合上面链接和DELETE documentation中的示例进行演示,并首先创建一个名为
purchases
的简单表,其中包含两个字段:接下来,我将使用INSERT和DELETE执行批处理 . 我最后会做DELETE,但是比INSERT更早的时间戳:
当我查询
userid
时:如您所见,INSERT持续存在,因为它具有最新的时间戳 . 如果我只是从cqlsh提示符中运行INSERT和DELETE(按此顺序),则查询将不返回任何内容 .