【数据库】Redis数据类型

news2025/7/19 21:15:29

目录

一, Key操作

1, 相关命令

2, 示例演示

二,字符串 String

1, 结构图

2,相关命令

3,示例演示

三, 列表 List

1, 结构图

2, 相关命令

3, 示例演示

四,无序 集合 Set

1,结构图

2,相关命令

3, 示例演示

五, 有序集合 sorted set

1, 结构图

2,相关命令

3, 示例演示

六, Hash

1, 结构图

2,相关命令

3,示例演示

七,位图 Bitmaps

1,介绍

2, 相关命令

1、setbit

2、getbit

3、bitcount

4、bitop 

八, HyperLogLog

1,简介

2,相关命令

3,示例演示

九,Geospatial

1, 简介

2,相关命令

3, 示例演示


数据类型

一, Key操作

1, 相关命令

序号

命令语法

描述

1

DEL key

该命令用于在 key 存在时删除 key

2

DUMP key

序列化给定 key ,并返回被序列化的值

3

EXISTS key

检查给定 key 是否存在,存在返回1,否则返回0

4

EXPIRE key seconds

为给定 key 设置过期时间,以秒计

5

EXPIREAT key timestamp

EXPIREAT 的作用和 EXPIRE 类似,都用于为 key 设置过期时间。不同在于 EXPIREAT 命令接受的时间参数是 UNIX 时间戳

6

PEXPIRE key milliseconds

设置 key 的过期时间以毫秒计

7

PEXPIREAT key milliseconds-timestamp

设置 key 过期时间的时间戳(unix timestamp) 以毫秒计

8

KEYS pattern

查找所有符合给定模式( pattern)的 key

9

MOVE key db

将当前数据库的 key 移动到给定的数据库 db 当中

10

PERSIST key

移除 key 的过期时间,key 将持久保持

11

PTTL key

以毫秒为单位返回 key 的剩余的过期时间

12

TTL key

以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)

13

RANDOMKEY

从当前数据库中随机返回一个 key

14

RENAME key newkey

修改 key 的名称

15

RENAMENX key newkey

仅当 newkey 不存在时,将 key 改名为 newkey

16

SCAN cursor [MATCH pattern] [COUNT count]

迭代数据库中的数据库键

17

TYPE key

返回 key 所储存的值的类型

18

SELECT db

选择数据库 数据库为0-15(默认一共16个数据库)

19

DBSIZE

查看数据库的key数量

20

FLUSHDB

清空当前数据库里面所有的key

21

FLUSHALL

清空所有数据库里面所有的key

22

ECHO

打印命令

说明: KEYS * 匹配数据库中所有key KEYS h?llo 匹配hello,hallo,hxllo等 KEYS h*llo 匹配hllo和heeello等 KEYS h[ae]llo 匹配hello和hallo

2, 示例演示

  1set  key  value----设置指定 key 的值

设置一个string类型的键为key,值为redis

set name redis

 

 2del key删除数据库下的键

删除name,floor两个键

 del name floor

 

 

 3,TYPE key-----查看key中所存的值得类型

查看name键中值的类型

type name

 

 

 

4, dbsize----获取当前数据库里面有多少键

dbsize

 

 

 5,EXISTS key---查看某个键是否存在

查看test键是否存在

exists test

 

 

 

 

 

 

 

 

二,字符串 String

String 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。

String 类型是二进制安全的,意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。

String 类型是 Redis 最基本的数据类型,String 类型的值最大能存储 512MB。

String类型一般用于缓存、限流、计数器、分布式锁、分布式Session。

1, 结构图

2,相关命令

序号

命令语法

描述

1

SET key value

设置指定 key 的值

2

GET key

获取指定 key 的值

3

GETRANGE key start end

返回 key 中字符串值的子字符,end=-1时表示全部

4

SETBIT key offset value

对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)

5

GETBIT key offset

对 key 所储存的字符串值,获取指定偏移量上的位(bit)

6

MSET key value [key value ...]

同时设置一个或多个 key-value 对

7

MGET key1 [key2..]

获取所有(一个或多个)给定 key 的值

8

GETSET key value

将给定 key 的值设为 value ,并返回 key 的旧值(old value)

9

SETEX key seconds value

将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)

10

SETNX key value

只有在 key 不存在时设置 key 的值

11

SETRANGE key offset value

用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始

12

STRLEN key

返回 key 所储存的字符串值的长度

13

MSETNX key value [key value ...]

同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在

14

PSETEX key milliseconds value

与 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间

15

INCR key

将 key 中储存的数字值增一

16

INCRBY key increment

将 key 所储存的值加上给定的增量值(increment)

17

INCRBYFLOAT key increment

将 key 所储存的值加上给定的浮点增量值(increment)

18

DECR key

将 key 中储存的数字值减一

19

DECRBY key decrement

key 所储存的值减去给定的减量值(decrement)

20

APPEND key value

如果 key 已经存在并且是一个字符串,APPEND 命令将指定的 value 追加到该 key 原来值 value 的末尾

 

 

 3,示例演示

 1set  key  value----设置指定 key 的值

设置一个string类型的键为key,值为redis

set name redis

 

 

2,select  数据库名---使用数据库

使用数据库1

 select 1

 

 

3 set  key  value----设置指定 key 的值

设置一个string类型的键为key,值为redis

set name redis

 

4flushall  删除所有数据库下的所有数据

此时打开数据库的图形化界面会发现

 数据库1与数据库0下都有name键

删除所有数据库中的所有键值对

 flushall

此时,重新刷新数据库会发现之前所有数据库

中的键值对消失

 

5flushdb   删除指定某个数据库下的所有数据

在数据库0和数据库1下新创建一个键值对

 select 0
 set name redis

select 0
set name redis

 

此时,数据库0和数据库1下面都有键值对

 

在数据库1下面使用flushdb,清空的是当前数据库下的所有键值对

此时在刷新数据库0和数据库1,发现数据库1下的键值对被删除了

 

 

 

6get   key  查看key的值

1 存储的键值为英文

在数据库1里面创建名为name值为redis的键值对

set name redis

查看键name里面的值

get name

 

2)存储的键值为中文

在数据库1里面创建名为floor值为  三   的键值对

set floor 三

查看floor键里面的值

使用命令 redis-cli --raw 登入

在切换到对应的数据库下获取键的值

 

 

 

7keys *----查看数据库下所有的键

查看数据库1下的所有键

keys *

 

 

8del key删除数据库下的键

删除多个键

 del name floor

 

删除一个键

del test

 

9, dbsize----获取当前数据库里面有多少键

dbsize

 

 

10incr---自增

incr age

 

 

 

11,decr--自减

decr age

 

 

12,incrby key 增长----按指定的速度增

正增长

incrby age 2

负增长

incrby age -2

 

 

 

13,decrby key 减少量---按指定的速度减少

正减少

decrby age 2

负减少

decrby age -2

 

 

14incrbyfloat key 增长量---按浮点型数增长

正增加

incrbyfloat price 0.5

负增加

incrbyfloat price -0.5

 

 

 

15,通过多个单词加冒号形成层级结构

set pro1:user:1 {id:1,name:xiaoming,age:19}

 

查看键的值

get pro1:user:1

 

此时,查看图形化界面,会发现层级结构

设置两个层级键值对

set pro1:product:1 {id:1,name:phone,price:3000}

set pro1:product:2 {id:2,name:computer,price:7998}

 

此时,查看图形化界面,会发现层级结构

 

 

 

 

 

三, 列表 List

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含 2^32^ - 1 个元素 (4294967295, 每个列表超过40亿个元素)。

List类型一般用于关注人、简单队列等。

1, 结构图

2, 相关命令

序号

命令语法

描述

1

LPUSH key value1 [value2]

将一个或多个值插入到列表头部

2

LPOP key

移出并获取列表的第一个元素

3

LRANGE key start stop

获取列表指定范围内的元素

4

LPUSHX key value

将一个值插入到已存在的列表头部

5

RPUSH key value1 [value2]

在列表中添加一个或多个值

6

RPOP key

移除列表的最后一个元素,返回值为移除的元素

7

RPUSHX key value

为已存在的列表添加值

8

LLEN key

获取列表长度

9

LINSERT key BEFORE|AFTER pivot value

在列表的元素前或者后插入元素

10

LINDEX key index

通过索引获取列表中的元素

11

LSET key index value

通过索引设置列表元素的值

12

LREM key count value

移除count个为value值的列表元素

13

LTRIM key start stop

对一个列表进行修剪,就是让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除

14

BLPOP key1 [key2 ] timeout

移出并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止

15

BRPOP key1 [key2 ] timeout

移出并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止

16

BRPOPLPUSH source destination timeout

从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它;如果列表没有元素会阻塞列表直到等待超时或发现可lpu弹出元素为止

17

RPOPLPUSH source destination

移除列表的最后一个元素,并将该元素添加到另一个列表并返回

 

 

3, 示例演示

1,LPUSH key value1 [value2]按照输入顺序向左插入

lpush name zhangsan lisi wangwu

2LRANGE key start stop  获取列表指定范围内的元素

lrange name 0 2

 

 

 

3RPUSH key value1 [value2]按照输入顺序向右插入

rpush name xiaoming xiaohong xiaozi

 

查看其中的元素

lrange name 0 5

 

 

 

4,LLEN key ---获取列表长度

llen name

 

 

 

5,BLPOP key1 [key2 ]   弹出左边的值

blpop name 1

 查看name键下的所有元素

lrange name 0 5

 

 

6,BRPOP key1 [key2 ]  弹出最右边的值

 brpop name 1

 

 

7,EXISTS key---查看某个键是否存在

查看test键是否存在

exists test

 

 

8,BRPOP key1 [key2 ] timeout 在时间范围内弹出最右边的值

先在一个会话弹出key的最左边的值

blpop test 100

 

在复制一个会话给key中添加元素

lpush test lisi wangwu

再返回第一个会话查看,发现最左边元素已经被弹出

用时9秒

 

 

 

9index  key  索引根据索引获取元素对应的值

获取第三个元素的值

lindex name 2

 

10,TYPE key-----查看key中所存的值得类型

type name

 

 

 

11,LSET key index value--通过索引设置对应元素的值

修改前

把索引2的值改为xiaoxiaoming

lset name 2 xiaoxiaoming

 

修改后

 

 

 

 

12,LREM key count value---移除列表中从左至右匹配到的countvalue

删除name列表中匹配到的第一个zhangsan

lrem name 1 zhangsan

 

此时,name列表下有以下元素

 

删除name列表从左只有匹配到的3个张三

lrem name 3 zhangsan

 

 

 

 

 

四,无序 集合 Set

Redis 的 Set 是 String 类型的无序集合。集合中成员是唯一的,这就意味着集合中不能出现重复的数据。Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 2^32^ - 1 (4294967295, 每个集合可存储40多亿个成员)。

Set类型一般用于赞、踩、标签、好友关系等。

1,结构图

2,相关命令

序号

命令语法

描述

1

SADD key member1 [member2]

向集合添加一个或多个成员

2

SMEMBERS key

返回集合中的所有成员

3

SCARD key

获取集合的成员数

4

SRANDMEMBER key [count]

返回集合中一个或多个随机数

5

SISMEMBER key member

判断 member 元素是否是集合 key 的成员

6

SREM key member1 [member2]

移除集合中一个或多个成员

7

SDIFF key1 [key2]

返回给定所有集合的差集

8

SDIFFSTORE destination key1 [key2]

返回给定所有集合的差集并存储在 destination 中

9

SINTER key1 [key2]

返回给定所有集合的交集

10

SINTERSTORE destination key1 [key2]

返回给定所有集合的交集并存储在 destination 中

11

SUNION key1 [key2]

返回所有给定集合的并集

12

SUNIONSTORE destination key1 [key2]

所有给定集合的并集存储在 destination 集合中

13

SMOVE source destination member

将 member 元素从 source 集合移动到 destination 集合

14

SPOP key

移除并返回集合中的一个随机元素

15

SSCAN key cursor [MATCH pattern] [COUNT count]

迭代集合中的元素

  • ==cursor==:游标
  • ==MATCH pattern==:查询 Key 的条件
  • ==Count count==:返回的条数,默认值为 10

SCAN 是一个基于游标的迭代器,需要基于上一次的游标延续之前的迭代过程。SCAN 以 ==0== 作为游标,开始一次新的迭代,直到命令返回游标 0 完成一次遍历。 此命令并不保证每次执行都返回某个给定数量的元素,甚至会返回 0 个元素,但只要游标不是 0,程序都不会认为 SCAN 命令结束,但是返回的元素数量大概率符合 Count 参数。另外,SCAN 支持模糊查询。

例:SSCAN names 0 MATCH test* COUNT 10 # 每次返回10条以test为前缀的key

 

  

3, 示例演示

 

1,SADD key member1 [member2]---向集合添加一个或多个成员

     成员值唯一,不能重复

向集合course中添加一个成员redis

add course redis

sadd course mysql

sadd course mongdb

2,SMEMBERS key---随机无序返回集合中的所有成员

smembers course

 

 

 

3,SREM key member1 [member2]---移除集合中一个或多个成员

srem course mysql

 

 

  

4,SINTER key1 [key2]----返回给定所有集合的交集

向集合xiaoming中添加成员xiaohong xiaozi xiaolan zhangsan

sadd xiaoming xiaohong xiaozi xiaolan zhangsan

 

向集合xiaohong 中添加成员xiaozi xiaolan wangwu

sadd xiaohong xiaozi xiaolan wangwu

 

无序查看xiaoming集合中的所有成员

 

无序查看xiaohong集合中的所有成员

 

查找xiaoming集合与xiaohong集合的共同成员

sinter xiaoming xiaohong

 

 

 

5,SDIFF key1 [key2]---返回给定所有集合的差集

查找是xiaoming集合但不是xiaohong集合的成员

sdiff xiaoming xiaohong

 

查找是xiaohong集合但不是xiaoming 集合的成员

sdiff xiaohong xiaoming

 

 

6xiaoming集合删除xiaohong成员

srem xiaoming xiaohong

 

 

 

7,SCARD key---获取集合的成员数

 scard xiaoming

 

 

 

五, 有序集合 sorted set

Redis 有序集合和集合一样也是string类型元素的集合且不允许重复的成员。不同的是每个元素都会关联一个==double类型的分数==。redis正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 2^32^ - 1 (4294967295, 每个集合可存储40多亿个成员)。

Zset类型一般用于排行榜等。

1, 结构图

 

2,相关命令

序号

命令语法

描述

1

ZADD key score1 member1 [score2 member2]

向有序集合添加一个或多个成员,或者更新已存在成员的分数

2

ZCARD key

获取有序集合的成员数

3

ZCOUNT key min max

计算在有序集合中指定区间分数的成员数

4

ZINCRBY key increment member

有序集合中对指定成员的分数加上增量 increment

5

ZLEXCOUNT key min max

在有序集合中计算指定字典区间内成员数量

6

ZRANGE key start stop [WITHSCORES]

通过索引区间返回有序集合指定区间内的成员

7

ZRANGEBYLEX key min max [LIMIT offset count]

通过字典区间返回有序集合的成员

8

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

通过分数返回有序集合指定区间内的成员

9

ZRANK key member

返回有序集合中指定成员的索引

10

ZREM key member [member ...]

移除有序集合中的一个或多个成员

11

ZREMRANGEBYLEX key min max

移除有序集合中给定的字典区间的所有成员

12

ZREMRANGEBYRANK key start stop

移除有序集合中给定的排名区间的所有成员

13

ZREMRANGEBYSCORE key min max

移除有序集合中给定的分数区间的所有成员

14

ZREVRANGE key start stop [WITHSCORES]

返回有序集中指定区间内的成员,通过索引,分数从高到低

15

ZREVRANGEBYSCORE key max min [WITHSCORES]

返回有序集中指定分数区间内的成员,分数从高到低排序

16

ZREVRANK key member

返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序

17

ZSCORE key member

返回有序集中,成员的分数值

18

ZINTERSTORE destination numkeys key [key ...]

计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中

19

ZUNIONSTORE destination numkeys key [key ...]

计算给定的一个或多个有序集的并集,并存储在新的 key 中

20

ZSCAN key cursor [MATCH pattern] [COUNT count]

迭代有序集合中的元素(包括元素成员和元素分值)

 

 

3, 示例演示

1,ZADD key score1 member1 [score2 member2]----向有序集合添加一个或多个成员

zadd grade 99 xiaoming 80 xiaohong 60 xiaohei 50 xiaozi 80 xiaolv

 

 

 2,ZCARD key---获取有序集合的成员数

  zcard grade

 

 

3,ZRANGE key start stop [WITHSCORES]---按照分值从小到大返回指定区间内的所有成员

zrange grade 0 4

3,ZREVRANGE key start stop [WITHSCORES]---按照分值从大到小返回指定区间内的所有成员

zrevrange grade 0 4

4,ZRANK key member---按照从小到大返回有序集合中指定成员的索引

返回xiaoming的索引

 zrank grade xiaoming

5,ZRANK key member---按照从大到小返回有序集合中指定成员的索引

zrevrank grade xiaoming

6,ZSCORE key member---返回成员的分数值

zscore grade xiaohei

7,ZSCAN key cursor [MATCH pattern] [COUNT count]---迭代有序集合中的元素(包括元素成员和元素分值)

zscan grade 0

8,ZINCRBY key increment member---有序集合中对指定成员的分数加上增量 increment

给xiaozi加10分

zincrby grade 10 xiaozi

9,ZREM key member [member ...]---移除有序集合中的一个或多个成员

删除xiaohei 的成绩

zrem grade xiaohei

六, Hash

Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。Redis 中每个 hash 可以存储 2^32^ - 1 键值对(40多亿)。

Hash类型一般用于存储用户信息、用户主页访问量、组合查询等。

1, 结构图

2,相关命令

序号

命令语法

描述

1

HSET key field value

将哈希表 key 中的字段 field 的值设为 value

2

HGET key field

获取存储在哈希表中指定字段的值

3

HGETALL key

获取在哈希表中指定 key 的所有字段和值

4

HEXISTS key field

查看哈希表 key 中,指定的字段是否存在

5

HSETNX key field value

只有在字段 field 不存在时,设置哈希表字段的值

6

HKEYS key

获取所有哈希表中的字段

7

HVALS key

获取哈希表中所有值

8

HLEN key

获取哈希表中字段的数量

9

HMGET key field1 [field2]

获取所有给定字段的值

10

HMSET key field1 value1 [field2 value2]

同时将多个 field-value (域-值)对设置到哈希表 key 中

11

HINCRBY key field increment

为哈希表 key 中的指定字段的整数值加上增量 increment

12

HINCRBYFLOAT key field increment

为哈希表 key 中的指定字段的浮点数值加上增量 increment

13

HDEL key field1 [field2]

删除一个或多个哈希表字段

14

HSCAN key cursor [MATCH pattern] [COUNT count]

迭代哈希表中的键值对

 

3,示例演示

1HSET key field value----将哈希表 key 中的字段 field 的值设为 value

 hmset hpe name zhangsan age 18 gender M birth 2000-01-01

2HGETALL key---获取在哈希表中指定 key 的所有字段和值

hgetall hpe

3HKEYS key---获取所有哈希表中的字段

hkeys hpe

 

 

 

4HVALS key---获取哈希表中所有值

 hvals hpe

 

 

 

 

5HLEN key---获取哈希表中字段的数量

hlen hpe

 

 

 

6HINCRBY key field increment---为哈希表 key 中的指定字段的整数值加上增量

hincrby hpe age 1

 

 

7HDEL key field1 [field2]---删除一个或多个哈希表字段

hdel hpe birth

 

 

 

 

七,位图 Bitmaps

1,介绍

现代计算机用二进制(位) 作为信息的基础单位, 1个字节等于8位, 例如“abc”字符串是由3个字节组成, 但实际在计算机存储时将其用二进制表示, “abc”分别对应的ASCII码分别是97、 98、 99, 对应的二进制分别是01100001、 01100010和01100011,如下图:

合理地使用操作位能够有效地提高内存使用率和开发效率。

Redis 6 中提供了 Bitmaps 这个“数据类型”可以实现对位的操作:

1)Bitmaps本身不是一种数据类型,实际上它就是字符串(key-value),但是它可以对字符串的位进行操作。

2)Bitmaps单独提供了一套命令,所以在Redis中使用Bitmaps和使用字符串的方法不太相同。 可以把Bitmaps想象成一个以位为单位的数组, 数组的每个单元只能存储0和1, 数组的下标在Bitmaps中叫做偏移量。

2, 相关命令

1、setbit

这个命令用于设置Bitmaps中某个偏移量的值(0或1),offset偏移量从0开始。格式如下:

setbit <key> <offset> <value>

例如,把每个独立用户是否访问过网站存放在Bitmaps中, 将访问的用户记做1,没有访问的用户记做0,用偏移量作为用户的id。

设置键的第offset个位的值(从0算起) , 假设现在有20个用户,userid=1,6,11,15,19的用户对网站进行了访问, 那么当前Bitmaps初始化结果如图:

 

 

 

1,设置unique:user 202317 偏移量为1,值为1

setbit unique:users:20230217 1 1

 

 

 

2,设置unique:user 202317 偏移量为6,值为1

setbit unique:users:20230217 6 1

 

 

 

 

3,设置unique:user 202317 偏移量为11,值为1

setbit unique:users:20230217 11 1

 

 

4,设置unique:user 202317 偏移量分别为1519,值为1

 

 

 

注意:

很多应用的用户id以一个指定数字(例如10000) 开头, 直接将用户id和Bitmaps的偏移量对应势必会造成一定的浪费, 通常的做法是每次做setbit操作时将用户id减去这个指定数字。

在第一次初始化Bitmaps时, 假如偏移量非常大, 那么整个初始化过程执行会比较慢, 可能会造成Redis的阻塞。

2、getbit

这个命令用于获取Bitmaps中某个偏移量的值。格式为:

getbit <key> <offset>

获取键的第offset位的值(从0开始算)。

获取id=1号的人是否签到(返回结果为1表示签到,0表示未签到)

getbit unique:users:20230217 1

 

 

 

3、bitcount

这个命令用于统计字符串被设置为1的bit数。

一般情况下,给定的整个字符串都会被进行计数,通过指定额外的 start 或 end 参数,可以让计数只在特定的位上进行。start 和 end 参数的设置,都可以使用负数值:比如 -1 表示最后一个位,而 -2 表示倒数第二个位,start、end 是指bit组的字节的下标数,二者皆包含。格式如下:

bitcount <key> [start end]

用于统计字符串从start字节到end字节比特值为1的数量。

 

(1)统计在第2个字节中有多少人访问网站

bitcount unique:users:20230217 1 1

 

(2)统计在第1-3个字节中有多少人访问网站

 

 

 

4、bitop

这个命令是一个复合操作, 它可以做多个Bitmaps的and(交集) 、 or(并集) 、 not(非) 、 xor(异或) 操作并将结果保存在destkey中。

格式如下:

bitop and(or/not/xor) <destkey> [key…]

1,设置unique:users:20230216 id1,2,5,9的值为 1

 

 

 

 

2,统计2023011720230116都访问过这个网站的id都有哪些(求交集)

(1)把20230216与20230217的交集放在unique:users:20230216and17中

bitop and unique:users:20230216and17 unique:users:20230216 unique:users:20230217

  

 

 

(2)统计unique:users:20230216and17中所有值为1的数量

bitcount unique:users:20230216and17

 

 

 

2,统计2023011720230116任意一天访问过这个网站的id都有哪些(求并集)

(1)把20230216与20230217的并集放在unique:users:20230216or17中

bitop or unique:users:20230216or17 unique:users:20230216 or unique:users:20230217

  

 

 

 

(2)统计unique:users:20230216or17中所有值为1的数量

 bitcount unique:users:20230216or17

 

 

 

 

八, HyperLogLog

1,简介

在工作当中,我们经常会遇到与统计相关的功能需求,比如统计网站PV(PageView页面访问量),可以使用Redis的incr、incrby轻松实现。

但像UV(UniqueVisitor,独立访客)、独立IP数、搜索记录数等需要去重和计数的问题如何解决?这种求集合中不重复元素个数的问题称为基数问题。

解决基数问题有很多种方案:

1)数据存储在MySQL表中,使用distinct count计算不重复个数

2)使用Redis提供的hash、set、bitmaps等数据结构来处理

以上的方案结果精确,但随着数据不断增加,导致占用空间越来越大,对于非常大的数据集是不切实际的。

为了能够降低一定的精度来平衡存储空间,Redis推出了HyperLogLog。

HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是:在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定的、并且是很小的。

在 Redis 里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。

但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。

什么是基数?

比如数据集 {1, 3, 5, 7, 5, 7, 8},那么这个数据集的基数集为 {1, 3, 5 ,7, 8},基数(不重复元素)为5。 基数估计就是在误差可接受的范围内,快速计算基数。

 

2,相关命令

序号

命令语法

描述

1

PFADD key element [element ...]

添加指定元素到 HyperLogLog 中

2

PFCOUNT key [key ...]

返回给定 HyperLogLog 的基数估算值

3

PFMERGE destkey sourcekey [sourcekey ...]

将多个 HyperLogLog 合并为一个 HyperLogLog

 

 

3,示例演示

1PFADD key element [element ...]---添加指定元素到 HyperLogLog

pfadd courses redis

pfadd courses monogodb

pfadd courses mysql

pfadd courses redis mysql mongodb

2PFCOUNT key [key ...]---返回给定 HyperLogLog 的基数估算值

pfcount courses(去重)

给ip中添加3个成员

 pfadd ip 192.168.168.130 192.168.268.128 192.168.168.130

查看里面有几个独立的ip

pfcount ip

将所有元素添加到指定HyperLogLog数据结构中。如果执行命令后HLL估计的近似基数发生变化,则返回1,否则返回0。

 

 

 

九,Geospatial

1, 简介

Redis 3.2 中增加了对GEO类型的支持。GEO,Geographic,地理信息的缩写。该类型,就是元素的2维坐标,在地图上就是经纬度。redis基于该类型,提供了经纬度设置,查询,范围查询,距离查询,经纬度Hash等常见操作。

2,相关命令

序号

命令语法

描述

1

geoadd key longitude latitude member [longitude latitude member...]

添加地理位置(经度,纬度,名称)

2

geopos key member [member...]

获得指定地区的坐标值

3

geodist key member1 member2 [m|km|ft|mi]

获取两个位置之间的直线距离

4

georadius key longitude latitude radius [m|km|ft|mi]

以给定的经纬度为中心,找出某一半径内的元素

3, 示例演示

1)添加城市坐标

例如,设置上海、重庆、深圳和北京的坐标

127.0.0.1:6379> geoadd china:city 121.47 31.23 shanghai

127.0.0.1:6379> geoadd china:city 106.50 29.53 chongqing 114.05 22.52 shenzhen 116.38 39.90 beijing

有效的经度从 -180 度到 180 度。有效的纬度从 -85.05112878 度到 85.05112878 度。

当坐标位置超出指定范围时,该命令将会返回一个错误。

已经添加的数据,是无法再次往里面添加的。

2)获取城市坐标

例如,获取上海的坐标。

127.0.0.1:6379> geopos china:city shanghai

3)用于获取两个位置之间的直线距离。

例如,获取北京和深圳的直线距离。

127.0.0.1:6379> geopos china:city beijing shanghai km

单位:

m:表示单位为米[默认值]。

km:表示单位为千米。

mi:表示单位为英里。

ft:表示单位为英尺。

4)用于获取指定坐标半径内的元素

例如,获取经度为 110,纬度为 30,半径为 1000KM 的所有城市。

127.0.0.1:6379> georadius china:city 110301000km

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/361078.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VO、DTO、BO、PO、DO区别

VO、DTO、BO、PO、DO区别 VO&#xff1a;&#xff08;View Object&#xff09;视图对象&#xff0c;一般位于Controller层&#xff0c;用于展示视图。DTO&#xff1a;&#xff08;Data Transfer Object&#xff09;数据传输对象&#xff0c; 即RPC 接口请求或传输出去的对象&a…

PMP值得考吗?含金量如何?

关于哪些证书可以考&#xff0c;这里我也不说其他的证书因为术业有专攻&#xff0c;其他证书的含金量估计我也没有更加专业的人士懂&#xff0c;我就推荐一下关于项目管理pmp证书的一些含金量吧&#xff01;对于想备考PMP的朋友或许有一些帮助。 一&#xff0c;PMP证书的价值体…

简易高并发内存池

文章目录从零实现一个高并发的内存池定长内存池定长内存池设计申请内存池用户申请用户归还&#xff08;释放&#xff09;总体代码测试对比&#xff08;malloc&#xff09;高并发内存池框架简介thread cache的设计申请部分释放部分第一层的测试central cache的设计申请部分释放部…

【Kubernetes】【十九】安全认证

第九章 安全认证 本章节主要介绍Kubernetes的安全认证机制。 访问控制概述 ​ Kubernetes作为一个分布式集群的管理工具&#xff0c;保证集群的安全性是其一个重要的任务。所谓的安全性其实就是保证对Kubernetes的各种客户端进行认证和鉴权操作。 客户端 在Kubernetes集群…

【Kubernetes】【十七】数据存储 基本存储 EmptyDir HostPath NFS

第八章 数据存储 ​ 在前面已经提到&#xff0c;容器的生命周期可能很短&#xff0c;会被频繁地创建和销毁。那么容器在销毁时&#xff0c;保存在容器中的数据也会被清除。这种结果对用户来说&#xff0c;在某些情况下是不乐意看到的。为了持久化保存容器的数据&#xff0c;ku…

2023只会“点点点”,被裁只是时间问题,高薪的自动化测试需要掌握那些技能?

互联网已然是存量市场了&#xff0c;对人员规模的需求正在放缓。在存量市场里&#xff0c;冗余人员和低效人员会被淘汰、被外包。而优秀的人才也会一直受到招聘方的青睐。所以我们就看到了近期行业里冰火两重天的一幕&#xff0c;一边是大量的低端测试工程师被淘汰、求职屡屡碰…

ssh设置:免密登入、修改默认端口、禁止root登入、限制错误登入次数

服务器&#xff1a; 客户端&#xff1a; 在下面不再说明服务器和客户端。 1.修改ssh默认端口 是在服务器中设置。 该设置涉及三部分&#xff1a;sshd配置文件修改/增加新端口、Selinux添加新端口、Firewall开放新端口。 vim /etc/ssh/sshd.config&#xff0c;找到#Port行&…

使用PHP+yii2调用asmx服务接口

一.创建服务端 1&#xff1a;创建一个ASP.NET web应用程序 2:选择空的模板 3&#xff1a;系统生成项目目录 4&#xff1a;右键项目-添加项-新建项 5&#xff1a;选择Web 服务&#xff08;ASMX&#xff09; 6&#xff1a;选择之后项目中会有一个Test.asmx服务程序&#xff0c;…

【闲聊杂谈】深入剖析SpringCloud Alibaba之Nacos源码

Nacos核心功能点 服务注册 Nacos Client会通过发送REST请求的方式向Nacos Server注册自己的服务&#xff0c;提供自身的元数据&#xff0c;比如ip地址、端口等信息。Nacos Server接收到注册请求后&#xff0c;就会把这些元数据信息存储在一个双层的内存Map中&#xff1b; 服…

(十八)、首页点赞高亮显示的功能实现【uniapp+uinicloud多用户社区博客实战项目(完整开发文档-从零到完整项目)】

1&#xff0c;首页点赞高亮显示的逻辑 思路&#xff1a;首先&#xff0c;查询所有在首页index页面中展示的文章id&#xff0c;存为一个id数组&#xff1b;然后利用dbcloud command命令和文章id数组&#xff0c;统一查询文章点赞表&#xff1b;其中加上两个筛选条件&#xff08…

阿里巴巴内网 Spring Cloud Alibaba 强势来袭,开创微服务的新时代

Spring Cloud 发展史 Spring Cloud 从 15 年的 3 月份推出之后&#xff0c;迅速在 Java 微服务生态中&#xff0c;成为开发人员的首选技术栈。 Spring Cloud 在 Spring Boot 的基础上&#xff0c;保留 Java 开发习惯&#xff0c;加入分布式特性&#xff0c;提供了一系列通用工…

0/1 nodes are available: 1 node(s) didn‘t match Pod‘s node affinity.

主要是需要确认你的yaml文件中是否有nodeSelector的配置&#xff0c;一般是因为k8s集群中没有相应的node节点匹配导致 这个错误消息表明您正在尝试在不符合Pod的节点亲和性规则的节点上运行Pod。这通常是由于节点选择器或节点亲和性规则设置不正确引起的。 以下是一些可能导致…

接口服务熔断方案

一.熔断方式1.中间件支持熔断2.支持节点级熔断2.支持url前缀匹配二.配置1.延迟方式expression "LatencyAtQuantileMS(50.0) > 100"//50%延迟超过100ms2.失败率方式expression "NetworkErrorRatio() > 0.30" //失败率超过30%3.组合方式expression …

9、GPT-1-2-3

GPT GPT系列即基于Transformer Decoder实现的预训练语言模型&#xff0c;在各类复杂的NLP任务中都取得了不错的效果&#xff0c;如文章生成、代码生成、机器翻译&#xff0c;Q&A等。 对于一个新的任务&#xff0c;GPT仅仅需要非常少的数据便可以理解该任务&#xff0c;并…

改进YOLO系列 | 谷歌团队 | CondConv:用于高效推理的条件参数化卷积

CondConv:用于高效推理的条件参数化卷积 论文地址:https://arxiv.org/pdf/1904.04971.pdf 代码地址:https://github.com/tensorflow/tpu/tree/master/models/official/efficientnet/condconv 卷积层是现代深度神经网络的基本构建模块之一。其中一个基本假设是,卷积核应该对数…

网络层协议

目录 MAC地址 前言 相关命令 IP地址 IPV4与IPV6 IPV6注意事项 IPV4 IPV4的10进制形式转化为2进制 IP地址的组成 子网掩码 网络地址与广播地址 子网掩码的CIDR的表示方法 子网掩码的使用 IP地址的分类&#xff08;IPV4为例&#xff09; 公有地址与私有地址 前言…

网络模型、网络连接

网络模型、网络连接网络模型OSI模型&#xff1a;应用层表示层会话层传输层网络层数据链路层物理层网络连接Socket(套接字)流套接字&#xff08;sock_stream&#xff09;数据报套接字(sock_dgram)原始套接字&#xff08;sock_raw&#xff09;网络模型 OSI模型&#xff1a; 百度…

Kroger EDI 855 采购订单确认报文详解

本文着重讲述Kroger EDI项目中&#xff0c;供应商发给Kroger的X12 855EDI 规范报文&#xff08;采购订单确认&#xff09;解读。 在此前的文章如何读懂X12报文中&#xff0c;我们对X12已经做了详细的介绍&#xff0c;大家可以以此为基础&#xff0c;深入了解855采购订单确认报…

CMake构建工具使用教程

1.简介 CMake是一个开源的、跨平台的C构建工具&#xff0c;通过平台和编译器无关的配置文件来声明构建目标&#xff0c;支持Make、ninja、MSBuild等多种底层构建工具&#xff0c;大多数IDE&#xff08;例如CLion、Visual Studio、Visual Studio Code等&#xff09;也都支持CMa…

【ZOJ 1067】Color Me Less 题解(vector+开方)

问题 颜色缩减是从一组离散颜色到较小颜色的映射。这个问题的解决方案需要在标准的24位RGB颜色空间中执行这样的映射。输入由十六个RGB颜色值的目标集合和要映射到目标集合中最接近的颜色的任意RGB颜色集合组成。为了我们的目的&#xff0c;RGB颜色被定义为有序三元组&#xff…