MGET 只支持字符串类型,对 hash、list、zset 等结构返回 nil 或 WRONGTYPE 错误;读 hash 用 HMGET,list 用 LRANGE,zset 用 ZRANGEBYSCORE;类型不兼容,需用 Lua 脚本做 TYPE 判断+分支调用。为什么不能直接用 MGET 抓多类型数据因为 MGET 只能取字符串类型的值,遇到 hash、list、zset 这类结构,它返回 nil 或报错 WRONGTYPE Operation against a key holding the wrong kind of value。你不是数据没存对,是命令用错了类型。MGET 本质是批量 GET,只认 string想读 hash 里的多个字段,得用 HMGET;读 list 某段用 LRANGE;读 zset 分数区间得用 ZRANGEBYSCORE不同结构的命令不兼容,没法靠一个命令统一处理用 Lua 脚本做"类型路由"的实际写法Lua 脚本在 Redis 里是原子执行的,且能调用所有服务端命令,适合做类型判断 + 分支读取。关键不是"写多酷的脚本",而是怎么让逻辑清晰、不踩类型误判的坑。先用 TYPE 查键类型,再分支:比如 if type == "hash" then return redis.call("HMGET", KEYS[1], unpack(ARGV))别用 redis.call("GET", ...) 硬试------一旦键是 list,脚本直接报错中断参数设计要明确:KEYS[1] 是目标键名,ARGV 放字段名或索引范围(如 "field1", "field2" 或 "0", "-1")示例片段:if redis.call("TYPE", KEYS[1]) == "hash" then return redis.call("HMGET", KEYS[1], unpack(ARGV))elseif redis.call("TYPE", KEYS[1]) == "string" then return {redis.call("GET", KEYS[1])}else return {}end批量读多个键+多种类型时的性能和边界问题一次 Lua 调用里处理太多键或太深的嵌套结构(比如遍历大 zset 再逐个 ZSCORE),容易触发 Redis 的慢日志或超时。这不是 Lua 多慢,是阻塞主线程的代价被放大了。 There's An AI For That 全球领先的 AI 聚合器,收集10,225个AI工具,可用于超过2,548个任务。
相关推荐
船长Talk2 小时前
Pandas数据清洗完整指南:8大核心技巧详解2301_815279522 小时前
如何在导航栏中实现左右两端对齐的菜单项布局战族狼魂2 小时前
40x40 矩阵控制系统专注VB编程开发20年2 小时前
VBA/VB6 ADO数据库查询jet+只读更快船长Talk2 小时前
NumPy+Pandas数据分析基础完全指南Wyz201210242 小时前
宝塔面板安装后显示无法连接数据库_检查MySQL服务状态2301_777599372 小时前
Redis如何优化大量对象存储_利用Hash结构减少内存碎片占用同元软控2 小时前
同元软控“电力能源系统数智运维解决方案”入选2025年江苏省信息技术应用创新典型解决方案2301_777599372 小时前
Python怎么解压tar.gz_tarfile模块提取打包文件操作