数据库设计 – Redis数据结构设计,用于对基于时间的值进行排序

我正在对数据流执行一些分析并在Redis频道上发布结果.消费者订阅这些频道并获得实时数据馈送.所有历史数据分析结果都将丢失.

现在我想添加在Redis中存储历史数据的功能,以便消费者可以查询这些历史数据(主要是按时间).由于分析结果按时间划分,将结果存储在Redis中的好设计是什么?

解决方法

使用redis sorted sets.

排序集根据“得分”存储数据,因此在您的情况下,只需使用毫秒时间戳;数据将自动排序,允许您使用开始/结束日期范围检索历史项目,这是一个示例…

将项目添加到已排序的集合中…

zadd historical <timestamp> <dataValue>

..添加一些样本数据..

zadd historical 1 data1
 zadd historical 2 data2
 zadd historical 3 data3
 zadd historical 4 data4
 zadd historical 5 data5
 zadd historical 6 data6
 zadd historical 7 data7

..使用开始/结束范围检索项目的子集…

zrangebyscore historical 2 5

..returns …

1) "data2"
2) "data3"
3) "data4"
4) "data5"

因此,在您的情况下,如果您想要检索最后一天的所有历史项目,请执行此操作…

zrangebyscore historical <currentTimeInMillis> <currentTimeInMillis - 86400000>

相关文章

(一)日志传送架构 (1.1)相关服务器 主服务器 :用于生产的服务器,上面运行这生产SQL Server数据库...
(一)事故背景 最近在SQL Server 2012生产数据库上配置完事物复制(发布订阅)后,生产数据库业务出现了...
(一)测试目的 目前公司使用的SQL SERVER 2012高可用环境为主备模式,其中主库可执行读写操作,备库既...
(一)背景个人在使用sql server时,用到了sql server的发布订阅来做主从同步,类似MySQL的异步复制。在...
UNION和OR谓词 找出 product 和 product2 中售价高于 500 的商品的基本信息. select * from product wh...
datawhale组队学习task03