Redis中存储数据如何保证查询出的数据是有序的

方法一:Redis有序集合(sorted set,zset)

Redis 有序集合与普通集合的相同点
一样也是 string 类型元素的集合,且不允许重复的成员

Redis 有序集合与普通集合的不同点
不同的是每个元素都会关联一个 double 类型的分数。Redis 正是通过分数来为集合中的成员进行从小到大的排序

有序集合的成员是唯一的,但分数(score)却可以重复。

实例:

通过命令 ZADD 向 Redis 的有序集合中添加了三个值并关联上分数

redis 127.0.0.1:6379> ZADD runoobkey 1 redis
(integer) 1
redis 127.0.0.1:6379> ZADD runoobkey 2 mongodb
(integer) 1
redis 127.0.0.1:6379> ZADD runoobkey 3 mysql
(integer) 1
redis 127.0.0.1:6379> ZADD runoobkey 3 mysql
(integer) 0
redis 127.0.0.1:6379> ZADD runoobkey 4 mysql
(integer) 0
redis 127.0.0.1:6379> ZRANGE runoobkey 0 10 WITHSCORES

1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "4"

方法二:Redis列表(list)

Redis列表具有普通列表的特性,即数据有序,可重复。但Redis列表底层采用双向链表实现,因此具备从两端压入或弹出元素的特性

实例:

从左侧依次压入数据

redis 127.0.0.1:6379> LPUSH runoobkey redis
(integer) 1
redis 127.0.0.1:6379> LPUSH runoobkey mongodb
(integer) 2
redis 127.0.0.1:6379> LPUSH runoobkey mysql
(integer) 3
redis 127.0.0.1:6379> LRANGE runoobkey 0 10

1) "mysql"
2) "mongodb"
3) "redis"

注意

因为不能对集合中的每个元素设置过期时间,所以针对集合元素过期清除的问题我们需要采取其他办法。例如:(1)可以设置定时任务;(2)有序集合的话,可以将score设置为timestamp代表它的过期时间

猜你喜欢

转载自blog.csdn.net/sinat_34241861/article/details/113845472