【发布时间】:2015-02-28 07:54:16
【问题描述】:
我有一个无序事件列表,我的任务是为它们存储第一次和最后一次出现的事件。
我在 Cassandra 中有以下列族:
CREATE TABLE events (
event_name TEXT,
first_occurrence BIGINT,
last_occurrence BIGINT,
PRIMARY KEY (event_name)
);
因此,如果我有一个名为“some_event”的事件并发生为 123456,我想要做的是在 MySQL 术语中看起来像这样的事情:
INSERT INTO events (event_name, first_occurence, last_occurence)
VALUES ('some_event', 123456, 123456)
ON DUPLICATE KEY UPDATE
first_occurrence = LEAST(first_occurrence, 12345),
last_occurrence = GREATEST(last_occurrence, 123456)
我打算在 Cassandra 中使用轻量级事务来完成它,如下所示:
INSERT INTO events(event_name, first_occurrence, last_occurrence) VALUES ('some_event', 12345, 12345) IF NOT EXISTS;
UPDATE events SET first_occurrence = 123456 WHERE event_name='some_event' IF first_occurrence > 123456;
UPDATE events SET last_occurrence = 123456 WHERE event_name='some_event' IF last_occurrence < 123456;
但事实证明,CQL3 不允许在轻量级事务的 IF 子句中使用 运算符。
所以我的问题是,进行这种条件更新的模式是什么?
【问题讨论】:
标签: cassandra conditional updates cql3 nosql