3

我正在开发应该使用 Apache Cassandra 来存储数据的 Web 应用程序。我需要存储每个项目的评分,然后获取评分最高的项目列表。

所以任务 - 以排序顺序存储项目的一些附加信息,以摆脱客户端排序或使用 ORDER BY 排序。

一种可能的选择是创建索引列族:

userId {
    100_ItemId1 : null, 
    90__ItemId2 : null,
    80__ItemId3 : null,
    80__ItemId4 : null
}

注意: userId 是行的键,100、90、80 - 是评分值

但是这里有一个删除的问题,我们应该知道以前的评级值来删除索引,它可能需要在 Column Family 中存储反转的信息:

reversed_userId{
   ItemId1 : 100_ItemId1, 
   ItemId2 : 100_ItemId2,
   ...
}

您能否说有一些模式可以有效地存储订购的物品?

PS:我不会使用 OrderPreservingPartitioner,因为它可以应用于整个 KeySpace,并且会损坏负载平衡和性能。

4

1 回答 1

0

我希望您会很高兴知道在 CQL 3 中您现在可以使用复合键结构进行排序。

http://www.datastax.com/dev/blog/whats-new-in-cql-3-0

例如:

 CREATE TABLE SortedPosts (
     post_id int,
     sort_order int,
     post_title text,
     PRIMARY KEY(post_id, sort_order)
 );

sort_order 将对其进行排序。你可以:

SELECT * FROM SortedPosts WHERE post_id = 1 ORDER BY sort_order ASC
SELECT * FROM SortedPosts WHERE post_id = 1 ORDER BY sort_order DESC
于 2012-12-26T20:26:57.300 回答