Redis HyperLogLog常用命令
基數(shù)并不是存儲(chǔ)元素,存儲(chǔ)元素消耗內(nèi)存空間比較大,而是給某一個(gè)有重復(fù)元素的數(shù)據(jù)集合(一般是很大的數(shù)據(jù)集合)評(píng)估需要的空間單元數(shù),所以它沒有辦法進(jìn)行存儲(chǔ),加上在工作中用得不多,我們要介紹一下 Redis 的 HyperLogLog 命令。
Redis 的 HyperLogLog 命令
命令行演示。
解說(shuō):首先往一個(gè)鍵為 h1 的 HyperLogLog 插入元素,讓其計(jì)算基數(shù),到了第 5 個(gè)命令“pfadd h1 a”的時(shí)候,由于在此以前已經(jīng)添加過(guò),所以返回了 0。它的基數(shù)集合是 {a,b,c,d},故而求集合長(zhǎng)度為 4;之后再添加了第二個(gè)基數(shù),它的基數(shù)集合是{a,z},所以在 h1 和 h2 合并為 h3 的時(shí)候,它的基數(shù)集合為 {a,b,c,d,z},所以求取它的基數(shù)就是 5。
在 Spring 中操作基數(shù),代碼如下所示。
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);從上面的代碼可以看到,增加一個(gè)元素到基數(shù)中采用 add 方法,它可以是一個(gè)或者多個(gè)元素,而求基數(shù)大小則是采用了 size 方法,合并基數(shù)則采用了 union 方法,其第一個(gè)是目標(biāo)基數(shù)的 key,然后可以是一到多個(gè) key。
總結(jié)
以上是生活随笔為你收集整理的Redis HyperLogLog常用命令的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: MySQL 限制查询结果的记录数
- 下一篇: Java final修饰符详解