我使用Redis作为我的有序集合数据的持久化。我的数据看起来像下面这样:
{text: 'Some text1', data: [1, 2, 3]},
{test: 'Some text2', data: [1, 3]}
.
.
.
如何更新列表中的某些元素?比如说我需要更新:
{test: 'Some text2', data: [1, 3]}
to
{test: 'Some text2', data: [1, 3, 7]}
您只能向已排序的集合中添加值或删除值。除了分数之外,您不能更改/更新它们。
相反,您可以直接将值保存为字符串:
SET text2 "{\"test\": \"Some text2\", data: [1, 3]}"
然后通过替换原始值来更新它们。
SET text2 "{\"test\": \"Some text2\", data: [1, 3, 7]}"
另一种选择是将值存储在哈希表中。
更新:
假设您有作为json持久化的用户对象且使用键“users:[id]”:
SET users:1 "{\"id\":1,\"name\":\"Santtu\"}"
然后将用户对象的键存储在排序集合"users"中。
ZADD users 1 "users:1"
ZADD users 2 "users:2"
ZRANGE users 0 9 # returns [ "users:1", "users:2", ...]
GET "users:1"
GET "users:2"
...
ZADD users 2 "users:123"
ZADD users 1 "users:456"
redis-cli
中使用以下命令:
zincrby <set_name> <amount_to_be_changed> <key>
例如:redis> ZADD myzset 1 "one"
(integer) 1
redis> ZADD myzset 2 "two"
(integer) 1
redis> ZINCRBY myzset 2 "one"
"3"
redis> ZRANGE myzset 0 -1 WITHSCORES
1) "two"
2) "2"
3) "one"
4) "3"