MySQL 8.0+ 不支持递归存储过程,因CALL自调用被明确禁止;真需求应使用递归CTE(如WITH RECURSIVE)封装树形查询,或用WHILE循环+临时表模拟,max_sp_recursion_depth仅控制嵌套深度,与递归无关。MySQL 8.0+ 怎么写递归存储过程MySQL 8.0 开始原生支持递归 WITH(CTE),但**存储过程本身不支持递归调用**------你不能在存储过程中直接用 CALL 调用自己,会报错 ERROR 1424 (HY000): Recursive stored procedures are not allowed。所以"递归存储过程"实际是伪命题。真需求通常是:遍历树形结构(如部门、分类、评论回复链),而你想把它封装成可复用的逻辑。可行做法是用**递归 CTE + 存储过程封装查询逻辑**,或用循环模拟递归。推荐优先用递归 CTE:简洁、安全、性能好,例如 WITH RECURSIVE t AS (...) SELECT * FROM t若必须用存储过程(比如要配合事务、多步处理),就用 WHILE 循环 + 临时表模拟递归:先把根节点插入临时表,再循环把子节点逐层 JOIN 进来别硬写 CALL proc_name(...) 自调用------MySQL 明确禁止,不是配置能绕过的max_sp_recursion_depth 是干啥的,设了有用吗max_sp_recursion_depth 控制的是「存储过程嵌套调用深度」,不是递归调用。比如 A 调 B,B 调 C,C 调 D......总共 4 层,就计为 4。它**完全不影响递归 CTE,也不允许你开启存储过程自调用**。默认值是 0,表示"不限制嵌套深度",但实际受栈空间限制;设成非 0 值(如 SET GLOBAL max_sp_recursion_depth = 10)只是给嵌套加个软上限,超了报 ERROR 1456 (HY000): Recursive limit 10 was exceeded。这个变量对"想写递归存储过程"的人毫无帮助------它管不了自调用,只管 A→B→C 这种线性嵌套修改需 GLOBAL 权限,且新连接才生效;当前会话用 SET SESSION 无效设太高可能耗尽 stack,设太低容易误伤正常嵌套逻辑(比如 ORM 自动生成的多层过程调用)替代方案:用递归 CTE 封装成视图或预编译语句真正该花时间的地方,是把树形查询逻辑写成可复用的递归 CTE,而不是折腾存储过程递归。CTE 支持参数化(通过外部变量或准备语句),也支持在存储过程中作为查询主体使用。 Ideogram Ideogram是一个全新的文本转图像AI绘画生成平台,擅长于生成带有文本的图像,如LOGO上的字母、数字等。
相关推荐
Dicky-_-zhang44 分钟前
系统容量规划与压测实战:从1万到100万QPS的科学扩容Li emily6 小时前
解决了加密货币api多币种订阅时的数据乱序问题Dicky-_-zhang6 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进2301_781571426 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】养肥胖虎6 小时前
RAG学习笔记(3):区分数据库检索与RAG的使用场景asdzx676 小时前
使用 Python 为 PDF 添加页码 (详细教程)AI技术控7 小时前
《Transformers are Inherently Succinct》论文解读:从“能表达什么”到“多紧凑地表达”_ku_ku_7 小时前
数据库系统原理 · 数据库应用开发 · 自学总结No8g攻城狮7 小时前
【人大金仓】wsl2+ubuntu22.04安装人大金仓数据库V9山峰哥8 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘