假设我有一个具有以下架构的 cassandra 表 xyz :
create table xyz(
xyzid uuid,
name text,
fileid int,
sid int,
PRIMARY KEY(xyzid));
我在列 fileid , sid 上创建索引:
CREATE INDEX file_index ON xyz (fileid);
CREATE INDEX sid_index ON xyz (sid);
我插入数据:
INSERT INTO xyz (xyzid, name , fileid , sid ) VALUES ( now(), 'p120' , 1, 100);
INSERT INTO xyz (xyzid, name , fileid , ssid ) VALUES ( now(), 'p120' , 1, 101);
INSERT INTO xyz (xyzid, name , fileid , sid ) VALUES ( now(), 'p122' , 2, 101);
我想使用索引列删除数据:
DELETE from xyz WHERE fileid=1 and sid=101;
为什么我会收到此错误?
InvalidRequest: code=2200 [Invalid query] message="Non PRIMARY KEY fileid found in where clause"
是否必须在 where 子句中为删除查询指定主键?
Cassandra 是否支持使用二级索引 s 进行删除?
使用二级索引删除数据需要做什么?
任何可以帮助的建议。
我正在使用 Data Stax Community Cassandra 2.1.8,但我也想知道 Data Stax Community Cassandra 3.2.1 是否支持使用索引列删除
谢谢