【Redis】如何使用sort对hash进行排序

  • 我们先插入几条hash数据:
127.0.0.1:6379> hmset soft:1 id 1 title mobile download 123 created 122
OK
127.0.0.1:6379> hmset soft:2 id 2 title android download 456 created 77
OK
127.0.0.1:6379> hmset soft:3 id 3 title ios download 789 created 88
OK
127.0.0.1:6379> hmset soft:4 id 4 title macos download 1011 created 98
  • 此时对象中应该有四组数据,我们再建立一个set集合,具体存放内容如下:
127.0.0.1:6379> sadd soft 1 2 3 4
(integer) 4
127.0.0.1:6379> smembers soft
1) "1"
2) "2"
3) "3"
4) "4"
  • 此时我们需要借助【sort】指令来进行排序:
/**
对【soft:*】 排序

【by soft:*->download desc】 根据download字段倒叙
【get soft:*->title】 获取title字段

**/

127.0.0.1:6379> sort soft by soft:*->download desc get soft:*->title 1) "macos" 2) "ios" 3) "android" 4) "mobile"
  • 这里我们可以延伸一道面试题:
我们这里有一个单词搜索功能,现在需要统计出单词频率出现最高的前三个?

我们可以采用这个排序方法来获取频率最高的前三个:

#我们先假设几个单词初始值,并且此时服务器还属于开放状态,用户可以进行搜词
先不考虑redis存储大小的能力,毕竟redis一个单节点大约可以存2.5亿个key

127.0.0.1:6379> hmset stat:java title java count 1
OK
127.0.0.1:6379> hmset stat:php title php count 3
OK
127.0.0.1:6379> hmset stat:c++ title c++ count 89
OK
127.0.0.1:6379> hmset stat:nodejs title nodejs count 545

然后进行sadd封装:

127.0.0.1:6379> sadd stat java php c++ nodejs
(integer) 4
127.0.0.1:6379> smembers stat
1) "java"
2) "c++"
3) "php"
4) "nodejs"

接下就可以做查询了:

127.0.0.1:6379> sort stat  by stat:*->count desc get stat:*->title limit 0 3
1) "nodejs"
2) "c++"
3) "php"
  • 【sort】其实还有很多功能,不过就不在这里赘述,感兴趣的小伙伴可自行谷歌百度学习。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值