你将如何获得最后 10 个键 redis?

Posted

技术标签:

【中文标题】你将如何获得最后 10 个键 redis?【英文标题】:How would you get the last 10 keys redis? 【发布时间】:2013-05-10 12:43:18 【问题描述】:

假设我有一个包含 1,000,000 个键的数据库。有没有办法知道该数据库中的最后 10 个键?

【问题讨论】:

不行,你必须自己实现 你会怎么做呢? 您可以将键存储在列表或排序集中 我明白了。所以我需要制作一个存储所有可用密钥的列表? “最后 10 个键”中的“最后一个”是什么? 【参考方案1】:

您需要使用以下命令将其维护为另一个列表。

Add new key to the front of the list  
LPUSH last10keys key

Retain only the last 10
LTRIM last10keys 0 9

Get the last keys - will return 10 or less
LRANGE mylist 0 9 

【讨论】:

【参考方案2】:

如果我不想更改缓存中的任何内容,作为一种解决方法,我会跟踪 AOF 文件以查看那里的最新更改。

tail -f /var/lib/redis/appendonly.aof

从那里,您可以看到使用的键、值和命令。

【讨论】:

这需要在配置文件中将 appendonly 设置为 yes。这不是默认设置。【参考方案3】:

一些命令有[LIMIT offset count],你可以填写并获得有限数量的项目。

like zrevrangebyscore key +inf 0 LIMIT 0 20,它为您提供排序集中的前 20 个项目。

【讨论】:

【参考方案4】:

您可以使用管道从 Redis 数据库中获取最后插入的密钥或特定密钥

这是我的代码示例:

r = redis.StrictRedis(host='localhost', port= 6379, db =0)
# Day1 hash for 24 hours 
# Key , Field , Value
r.hset("31/8/21", "12am", "/home/user/video1.mp4")
r.hset("31/8/21", "1am", "/home/user/video2.mp4")
r.hset("31/8/21", "2am", "/home/user/video3.mp4")
r.hset("31/8/21", "3am", "/home/user/video4.mp4")
r.hset("31/8/21", "4am", "/home/user/video5.mp4")
.
.
#Created sorted set for all the date hashes into single "date" key
r.sadd("date", "25/8/21")
r.sadd("date", "26/8/21")
r.sadd("date", "27/8/21")
r.sadd("date", "28/8/21")
r.sadd("date", "29/8/21")
r.sadd("date", "30/8/21")
r.sadd("date", "31/8/21")
r.save

@app.get("/lastweek")
def sortweek():
        lastweeklist = r.sort("date", 27, -1, alpha=True) #sorted set key > date
        pipe = r.pipeline()
        for keys in lastweeklist:
                pipe.hgetall(keys) #hvals
        week1 = []
        for week in pipe.execute():
                week1.append(week)
        return week1

【讨论】:

以上是关于你将如何获得最后 10 个键 redis?的主要内容,如果未能解决你的问题,请参考以下文章

如何在redis中存储多个字段,并根据某些字段获得前10个结果

如何获得最后 10 个然后显示随机 5

如何获得最后的日期和最近的日期

请教各位,如何获得redis中key的已经存在的时间

LeetCode1561. 你可以获得的最大硬币数目(C++)

LeetCode1561. 你可以获得的最大硬币数目(C++)