最小可行路径是为每个用户创建独立Set键(如user:123:tags),用SADD添加标签、SMEMBERS查询,确保标签标准化;避免字符串拼接、KEYS扫描及反向索引维护,高频查询再引入RedisSearch或Elasticsearch。用 SADD 和 SMEMBERS 管理用户标签的最小可行路径Redis 的 Set 天然适合存用户标签------自动去重、无序、支持交并差。最直接的做法是:每个用户一个 key,比如 user:123:tags,每次打标就 SADD user:123:tags "vip" "ios" "active",查标签就 SMEMBERS user:123:tags。注意别把标签当字符串拼接存(如 SET user:123:tags "vip,ios,active"),那样后续增删改得取出来解析、再拼回去,既慢又容易出错。SADD 返回值是本次新增元素个数,可用来判断是否真打了新标签(返回 0 表示全已存在)标签名建议统一小写、去空格、避免特殊符号,否则 "VIP" 和 "vip" 会被当成两个标签如果用户量极大(千万级),SMEMBERS 全量拉取可能阻塞,后面会提到分页替代方案批量查「有某几个标签」的用户要用 SSCAN + 应用层过滤,别硬扫Redis 没有原生的"查所有带 vip 且带 ios 的用户"语法。想按标签反查用户,常见错误是建一堆反向索引 key(如 tag:vip:users),但维护成本高:用户删标签时得同步删多个地方,事务难保一致。更务实的做法是:用 SSCAN 扫描所有 user:*:tags key,每次取一批(比如 SSCAN user:123:tags 0 COUNT 100),在应用代码里做集合判断(比如 Python 用 set(tags) >= {"vip", "ios"})。SSCAN 是唯一安全遍历 Set 的方式,SMEMBERS 在大数据量下会卡主线程扫描前先用 KEYS user:*:tags?千万别------生产环境禁用,会阻塞 Redis;改用 SCAN 配合模式匹配如果查询频次高、延迟敏感,再考虑用 RedisSearch 或导出到 Elasticsearch 建倒排索引SINTER 做多标签交集要小心 key 不存在或为空想快速拿到"既是 vip 又是 ios 用户"的 ID 列表,可以为每个标签建一个用户 Set:tag:vip:users、tag:ios:users,然后 SINTER tag:vip:users tag:ios:users。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
xcLeigh2 小时前
KES 数据库存储过程、函数、触发器实战m0_596406372 小时前
mysql如何配置审计日志输出_mysql audit_log_format设置geBR OTTE2 小时前
flask后端开发(8):Flask连接MySQL数据库+ORM增删改查识君啊2 小时前
中小厂数据库事务高频面试题2301_816660212 小时前
Bootstrap框架的最小宽度限制是多少OtIo TALL2 小时前
SQL-触发器(trigger)的详解以及代码演示lwx572802 小时前
MySQL 数据库自动化备份脚本:从入门到生产实践水木流年追梦2 小时前
CodeTop Top 300 热门题目2-最长回文子串狗都不学爬虫_2 小时前
小程序逆向 - Hai尔(AliV3拖动物品)