zoukankan      html  css  js  c++  java
  • 【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】其实还有很多功能,不过就不在这里赘述,感兴趣的小伙伴可自行谷歌百度学习。
  • 相关阅读:
    spring boot整合quartz存储到数据库
    java多线程定时器和java判断一个时间是否在时间区间内和用正则表达式获取String字符串之间的数据
    maven项目通过java加载mqtt存储到mysql数据库,实现发布和接收
    java往MongDB导入大量数据
    SSH面试题收藏
    Spring面试题
    Hibernate面试题收藏
    Spring MVC
    浅谈 Struts2 面试题收藏
    JSP 新闻发布会
  • 原文地址:https://www.cnblogs.com/boluopabo/p/13092001.html
Copyright © 2011-2022 走看看