Redis HyperLogLog常用命令
生活随笔
收集整理的這篇文章主要介紹了
Redis HyperLogLog常用命令
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
基數并不是存儲元素,存儲元素消耗內存空間比較大,而是給某一個有重復元素的數據集合(一般是很大的數據集合)評估需要的空間單元數,所以它沒有辦法進行存儲,加上在工作中用得不多,我們要介紹一下 Redis 的 HyperLogLog 命令。
Redis 的 HyperLogLog 命令
命令行演示。
解說:首先往一個鍵為 h1 的 HyperLogLog 插入元素,讓其計算基數,到了第 5 個命令“pfadd h1 a”的時候,由于在此以前已經添加過,所以返回了 0。它的基數集合是 {a,b,c,d},故而求集合長度為 4;之后再添加了第二個基數,它的基數集合是{a,z},所以在 h1 和 h2 合并為 h3 的時候,它的基數集合為 {a,b,c,d,z},所以求取它的基數就是 5。
在 Spring 中操作基數,代碼如下所示。
ApplicationContext applicationContext = new ClassPathXmlApplicationcontext("applicationContext.xml"); RedisTemplate redisTemplate = applicationContext.getBean(RedisTemplate.class); redisTemplate.opsForHyperLogLog().add("HyperLogLog", "a", "b" , "c", "d", "a"); redisTemplate.opsForHyperLogLog().add("HyperLogLog2", "a"); redisTemplate.opsForHyperLogLog().add("HyperLogLog2", "z"); Long size = redisTemplate.opsForHyperLogLog().size("HyperLogLog"); System.err.println(size); size = redisTemplate.opsForHyperLogLog().size("HyperLogLog2"); System.err.println(size); redisTemplate.opsForHyperLogLog().union ("des_key","HyperLogLog","HyperLogLog2"); size = redisTemplate.opsForHyperLogLog().size("des_key"); System.err.println(size);從上面的代碼可以看到,增加一個元素到基數中采用 add 方法,它可以是一個或者多個元素,而求基數大小則是采用了 size 方法,合并基數則采用了 union 方法,其第一個是目標基數的 key,然后可以是一到多個 key。
總結
以上是生活随笔為你收集整理的Redis HyperLogLog常用命令的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL 限制查询结果的记录数
- 下一篇: mysql frm 英文全称_FRM考试