gpt4 book ai didi

Cassandra CQL3 条件插入/更新

转载 作者:行者123 更新时间:2023-12-05 00:23:07 25 4
gpt4 key购买 nike

我有一个无序事件列表,我的任务是为它们存储第一次和最后一次出现。

我在 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?在 2.1.1 中通过 CASSANDRA-6839 添加了对 LWT 不等条件的支持:

cqlsh:test> UPDATE events SET first_occurrence = 123456 WHERE event_name='some_event' IF first_occurrence > 1;

[applied]
-----------
True

关于Cassandra CQL3 条件插入/更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28779465/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com