我有一张有下一栏的table,
name text, //partition key
tags map<text, text>
我还有一个关于“标签”列的二级索引。现在我想问一下,
select * from <table_name> where tags contains {'a':'b','x':'y'}
有可能吗?如果不是,我可以只使用“contains{'a':'b'}”进行查询吗?
这个设计不好吗?如果是,如何纠正(注:名称与标记有1->n关系)
我有一张有下一栏的table,
name text, //partition key
tags map<text, text>
我还有一个关于“标签”列的二级索引。现在我想问一下,
select * from <table_name> where tags contains {'a':'b','x':'y'}
有可能吗?如果不是,我可以只使用“contains{'a':'b'}”进行查询吗?
这个设计不好吗?如果是,如何纠正(注:名称与标记有1->n关系)
1条答案
按热度按时间gcxthw6b1#
问题1
对于Map集合,cassandra允许在键、值或条目上创建索引(这仅适用于Map)。
因此,首先要在Map上创建索引:
然后您可以查询:
另一种解决方案是冻结集合并在其上创建索引:
然后,您可以通过以下方式查询值:
我认为上面的解决方案不是很好,因为你可以很容易地扫描整个集群。您的访问类型将使用和索引,而不是分区键。
问题2
另一种解决方案是创建如下表:
键和值列将保存标记的值。它们也是分区键,因此您可以查询数据,如:
为了搜索所有标记,您将需要运行几个查询,但是您可以在应用程序级别聚合结果。