news 2026/4/22 8:33:43

Redis如何利用位图快速判断数据存在性

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Redis如何利用位图快速判断数据存在性

用 SETBIT 和 GETBIT 做存在性判断最直接:SETBIT 设定位为 1,GETBIT 查该位是否为 1,O(1) 时间、极省空间;不可用 BITCOUNT 替代,不支持三态,需确保 ID 到偏移量映射一致。用 SETBIT 和 GETBIT 做存在性判断最直接Redis 位图(Bitmap)本质是字符串的底层操作,SETBIT 把某一位设为 1,GETBIT 查某一位是否为 1——这比存完整 key 更省空间,也比用 EXISTS 查 key 是否存在更快(尤其在海量稀疏数据场景下)。但注意:位图不自动扩容,SETBIT 写入超出当前长度的位置会自动补零,而 GETBIT 查询未写过的位默认返回 0。适合判断“某 ID 是否被标记过”,比如用户签到、设备在线状态、风控黑名单 ID不要用它查“值是多少”,位图只存 0/1,没有中间态SETBIT user:sign:20240501 <uid> 1 中 <uid> 是整数偏移量,不是字符串 ID;如果原始 ID 是字符串,得先映射成唯一递增整数(比如用 INCR 或预分配 ID 段)单个字符串最大支持 232 位(约 512MB),超了会报错 ERR bit offset is not an integer or out of range别把 BITCOUNT 当存在性检查用BITCOUNT 统计 1 的个数,常被误用来“间接判断是否存在”——比如先 BITCOUNT 再看是否 > 0。这多了一次全量扫描,完全没必要。只要确认某一位是 1,就代表存在;查一位用 GETBIT 是 O(1),查全量是 O(N)。错误做法:BITCOUNT user:sign:20240501 然后判断结果是否非零正确做法:GETBIT user:sign:20240501 <uid>,返回 1 就存在,0 就不存在(注意:0 不代表“明确不存在”,而是“没被设过 1”)如果业务要求区分“从未设置”和“显式设为 0”,位图做不到——它没有三态,只有 0 和 1,且未设置位默认读作 0用 BITOP AND 做交集判断时小心空 key想判断“用户是否在多个条件集合中都存在”,比如“既签到又完成实名又通过风控”,常用 BITOP AND dest k1 k2 k3 得到共同位,再 GETBIT dest uid。但只要任意一个源 key 不存在,BITOP 会把它当作全 0 字符串参与运算,结果可能全 0,导致误判。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 8:32:24

Bootlint表单组件验证:确保Bootstrap表单正确性的完整指南

Bootlint表单组件验证&#xff1a;确保Bootstrap表单正确性的完整指南 【免费下载链接】bootlint HTML linter for Bootstrap projects 项目地址: https://gitcode.com/gh_mirrors/bo/bootlint Bootlint是一款专为Bootstrap项目设计的HTML验证工具&#xff0c;能够帮助开…

作者头像 李华
网站建设 2026/4/22 8:33:22

Bliss.js扩展方法详解:如何创建自定义DOM操作函数

Bliss.js扩展方法详解&#xff1a;如何创建自定义DOM操作函数 【免费下载链接】bliss Blissful JavaScript 项目地址: https://gitcode.com/gh_mirrors/bl/bliss Bliss.js是一个轻量级的JavaScript库&#xff0c;专注于提供简洁高效的DOM操作能力。本文将详细介绍如何使…

作者头像 李华
网站建设 2026/4/22 8:30:57

5分钟搞定B站视频下载:免费获取4K高清资源的终极指南

5分钟搞定B站视频下载&#xff1a;免费获取4K高清资源的终极指南 【免费下载链接】bilibili-downloader B站视频下载&#xff0c;支持下载大会员清晰度4K&#xff0c;持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 还在为无法离线观看B…

作者头像 李华
网站建设 2026/4/17 9:14:24

Lungo.js设备检测与环境适配:智能识别并优化不同设备体验

Lungo.js设备检测与环境适配&#xff1a;智能识别并优化不同设备体验 【免费下载链接】Lungo.js A framework for developers who want to design, build and share cross device applications. 项目地址: https://gitcode.com/gh_mirrors/lu/Lungo.js Lungo.js是一款专…

作者头像 李华