• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    使用go操作redis的有序集合(zset)

    我就废话不多说了,大家还是直接看代码吧~

    package main
    import (
     "fmt"
     "github.com/garyburd/redigo/redis"
    )
    func main() {
     // 连接redis数据库,指定数据库的IP和端口
     conn, err := redis.Dial("tcp", "36.99.16.197:6379")
     if err != nil {
     fmt.Println("Connect to redis error", err)
     return
     } else {
     fmt.Println("Connect to redis ok.")
     }
     // 函数退出时关闭连接
     defer conn.Close()
     // 执行一个有序zset插入
     _, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot1")
     if err != nil {
     fmt.Println("redis set failed:", err)
     }
     // 再执行一个有序zset插入
     _, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot2")
     if err != nil {
     fmt.Println("redis set failed:", err)
     }
     // 读取指定zset
     user_map, err := redis.StringMap(conn.Do("ZRANGE", "mykey", 0, 10, "withscores"))
     if err != nil {
     fmt.Println("redis get failed:", err)
     } else {
     fmt.Printf("Get mykey: %v \n", user_map)
     }
     for user := range user_map {
     fmt.Printf("user name: %v %v\n", user, user_map[user])
     }
    }
    

    输出:

    Connect to redis ok.
    Get mykey: map[robot1:1 robot2:1]
    user name: robot1 1
    user name: robot2 1

    补充:Redis中zset的golang实现

    zset

    初衷是在不用Redis的前提下实现排行榜

    项目地址https://github.com/liyiheng/zset

    Installation

    go get -u github.com/liyiheng/zset

    Usage

    Removed RWLock in the SortedSet.

    Just implement it yourself if you need.

    s := zset.New()
    // add data
    s.Set(66, 1001, "test1")
    s.Set(77, 1002, "test2")
    s.Set(88, 1003, "test3")
    s.Set(100, 1004, "liyiheng")
    s.Set(99, 1005, "test4")
    s.Set(44, 1006, "test5")
    // update data
    s.Set(44, 1001, "test1")
    // get rank by id
    rank, score, extra := s.GetRank(1004, false)
    // get data by rank
    id, score, extra := s.GetDataByRank(0, true)
    // get data by id
    dat, ok := s.GetData(1001)
    // delete data by id
    s.Delete(1001)
    

    Benchmark

    go test -test.bench=".*"
    BenchmarkSortedSet_Add-4   1000000  4121 ns/op
    BenchmarkSortedSet_GetRank-4  500000  3592 ns/op
    BenchmarkSortedSet_GetDataByRank-4 2000000  667 ns/op
    PASS
    ok zset 11.365s

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • SpringBoot集成Redisson实现延迟队列的场景分析
    • springboot+websocket+redis搭建的实现
    • java、spring、springboot中整合Redis的详细讲解
    • 关于Springboot2.x集成lettuce连接redis集群报超时异常Command timed out after 6 second(s)
    • 如何自定义redis工具jar包供其他SpringBoot项目直接使用
    • 使用SpringBoot集成redis的方法
    • springboot连接Redis的教程详解
    • SpringBoot和Redis实现Token权限认证的实例讲解
    • SpringBoot集成Redis实现消息队列的方法
    • springboot基于Redis发布订阅集群下WebSocket的解决方案
    • springboot2整合redis使用lettuce连接池的方法(解决lettuce连接池无效问题)
    • php使用redis的有序集合zset实现延迟队列应用示例
    • SpringBoot使用Redis的zset统计在线用户信息
    上一篇:使用go读取gzip格式的压缩包的操作
    下一篇:golang使用aes库实现加解密操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    使用go操作redis的有序集合(zset) 使用,操作,redis,的,有序,