1

我正在使用 Redis 在哈希中存储一堆“Foos”:

foo:<id> => {
    name = 'whatever',
    status = 'incomplete|complete|removed',
    user = <user_id>,
    ...
}

我想设置一个索引,这样我就可以为特定用户提取具有特定状态的 Foos。我想出的最好的方法是使用这样命名的集合:

foo:user:<user_id>:status:<status> => [ <foo_id>, <foo_id2>, ... ]

但这似乎很笨拙,我必须确保跟踪旧状态并在更改状态时将其从一组中删除,以保持数据一致。我可以在这里使用更聪明的结构吗?

4

1 回答 1

1

我认为您考虑存储这些东西的方式很好。foo:user:<user_id>:status:<status>如果您认为名称太长,您可以随时更改名称,但这个想法是有道理的。我要添加的一件事是您应该创建一个简短的 lua 函数,通过从 foo 获取旧状态,将 foo 的状态更新为新状态,然后更新旧状态集和新状态,为您更新状态' 放。这些操作都是 O(1),所以它不会很昂贵(尤其是因为它的 Lua),并且由于所有内容都将由一个小脚本管理,因此您无需担心每次都在代码中完成所有操作.

于 2013-06-21T21:04:48.987 回答