Redis的三种特殊数据类型

举报
哥的时代 发表于 2023/12/24 22:40:06 2023/12/24
【摘要】 一、Redis geospatial 地理位置1.geoadd:将指定的地理空间位置(纬度、经度、名称)添加到指定的key中。geoadd china:city 121.472644 31.231706 shanghaigeoadd china:city 120.619585 31.299379 suzhougeoadd china:city 116.405285 39.904989 be...

一、Redis geospatial 地理位置

  • 1.geoadd:将指定的地理空间位置(纬度、经度、名称)添加到指定的key中。
geoadd china:city 121.472644 31.231706 shanghai
geoadd china:city 120.619585 31.299379 suzhou
geoadd china:city 116.405285 39.904989 beijing
geoadd china:city 113.280637 23.125178 guangzhou 113.26197 23.10379 haizhuqu

往china:city这个key里,添加了5个地方的经纬度:上海、苏州、北京、广州、广州海珠区。

  • 2.geopos:从key里返回所有给定位置元素的位置(经度和纬度)。
geopos china:city suzhou shanghai

返回位置的坐标。返回位置的坐标。

  • 3.geodist:返回两个给定位置之间的距离。如果两个位置之间的其中一个不存在, 那么命令返回空值。

单位:
- m 表示单位为米(默认)。
- km 表示单位为千米。
- mi 表示单位为英里。
- ft 表示单位为英尺。

geodist china:city suzhou shanghai km

返回两地的距离

  • 4.georadius:以给定的经纬度为中心, 返回键包含的位置元素当中, 与中心的距离不超过给定最大距离的所有位置元素。
georadius china:city 121.49295 31.22337 30 km

我以 上海黄浦区的坐标121.49295 31.22337为中心,寻找30km之内的城市。
再远点,100km之内,还可以找到suzhou,加上withdist显示出距离。

georadius china:city 121.49295 31.22337 100 km withdist

再加上count,只返回我指定的数量。

georadius china:city 121.49295 31.22337 100 km withdist withcoord count 1
  • 5.georadiusbymember:这个命令和 georadius命令一样, 都可以找出位于指定范围内的元素。但是这里不是指定中心点坐标,而是指定以哪个元素为中心点。
georadiusbymember china:city suzhou 100 km withdist

这里以元素suzhou为中心点,找周围100km内的其他元素。

  • 6.geohash:一个或多个位置元素,用hash表示。
geohash china:city suzhou shanghai

返回11个字符的Geohash字符串,代表当前经纬度的字符串,就是换了个形式,将二维的经纬度转化成了一个一维的字符串。如果2个字符串越接近,则2个位置距离也越近

geo的底层原理还是zset,我们可以使用zset命令操作geo,比如移除geo里的城市。

zrem china:city haizhuqu

二、Redis Hyperloglog 基数统计的算法

基数:一个集合中的不重复元素的个数。

优点:占用的内存是固定的,2^64不同的元素的技术,只需要废12KB内存!如果要从内存角度来比较的话 Hyperloglog 首选!

实例:网页的UV(一个人访问一个网站多次,但还是算作一个人)

  • 1.PFadd:创建元素
PFadd mykey a b c d e f
  • 2.PFCOUNT:统计key元组元素的基数数量
PFCOUNT mykey
  • 3.PFMERGE:合并两组元组
PFMERGE mykey3 mykey mykey2

image.png

错误率:0.81%,如果允许容错,那么可以选择Hyperloglog。

三、Redis Bitmaps 位存储(0、1)

Bitmaps 位图,数据结构!都是操作二进制位来进行记录,就只有0和1两个状态!

365天= 365 bit1字节= 8bit 46个字节左右!

  • SETBIT key offset value
    对key存储的字符串,设置或者清除指定偏移量上的位(bit),位的设置或者清除取决于value参数,0/1;当key不存在时,自动生成一个新的字符串。字符串会进行伸展确保value保存在指定的偏移量上。字符串进行伸展时,空白位置以0填充。

    offset 范围:

    0~2^32

    返回值:
    指定偏移量原来存储的位

  • GETBIT key offset
    获取指定偏移量上的位(bit),当offset比字符串长度大,或者key不存在,返回0;
    返回值:
    字符串值指定偏移量上的位(bit)

  • BITCOUNT key [start] [end]
    计算给定字符串中,被设置为1的bit位的数量。start和end参数可以指定查询的范围,可以使用负数值。-1代表最后一个字节,-2代表倒是第二个字节。

    注意:start和end是字节索引,因此每增加1 代表的是增加一个字符,也就是8位,所以位的查询范围必须是8的倍数。
    返回值:
    被设置为1的位的数量


总结

以上就是Redis的三种特殊数据类型,希望对你有所帮助

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。