mysqldump 不加 --routines 不会导出函数,该参数同时导出函数和存储过程,恢复需 CREATE ROUTINE 权限并确保 DELIMITER 结构完整及跨版本兼容性。mysqldump 不加 --routines 就不会导出函数默认情况下 mysqldump 只导出表结构和数据,函数、存储过程、触发器这些都属于"routine",必须显式开启开关。不加 --routines,哪怕你用 --all-databases 或指定了具体库,函数定义照样消失。导出时漏掉这个参数,恢复后调用 CALL my_func() 会直接报错 PROCEDURE db.my_func does not exist--routines 会同时导出函数(FUNCTION)和存储过程(PROCEDURE),无法单独只选函数如果只想要函数,导出后得手动从 SQL 文件里删掉 CREATE PROCEDURE 块,别指望 mysqldump 提供过滤选项该参数不依赖 --databases,但建议一起用:例如 mysqldump --routines --databases mydb > backup.sql恢复时权限不足会导致 CREATE FUNCTION 被跳过MySQL 恢复函数时,需要用户有 CREATE ROUTINE 权限;否则 source backup.sql 或 mysql < backup.sql 过程中,遇到 CREATE FUNCTION 语句会静默失败或报错 ERROR 1418 (HY000),而后续的表数据可能照常导入,造成"看起来恢复成功,实则函数丢了"的假象。检查当前用户权限:SHOW GRANTS FOR CURRENT_USER;,确认含 GRANT CREATE ROUTINE ON *.* TO ...临时启用 log_bin_trust_function_creators=1(仅当启用了二进制日志且函数非确定性时才需),否则可能卡在 ERROR 1418不要用普通应用账号恢复,优先用 root 或明确授过 CREATE ROUTINE 和 ALTER ROUTINE 的账号函数体里含分号会破坏 mysqldump 输出的 SQL 格式mysqldump 导出函数时,会自动把 DELIMITER 切换逻辑写进 SQL 文件(比如先设为 $$,再还原)。但如果函数定义本身没按规范写------比如函数体里用了未转义的分号、或者 DELIMITER 写错位置------会导致导出的 SQL 文件语法错误,恢复时报 ERROR 1064。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
阿丰资源2 小时前
基于SpringBoot的在线视频教育平台的设计与实现(附源码+数据库+文档,一键运行)qq_460978402 小时前
Python爬虫怎么模拟手机端抓取_设置手机型号User-Agent字符串love530love2 小时前
Clink 调校指南:让 Windows CMD 拥有现代终端的便捷体验c++之路2 小时前
C++ 动态内存小熊Coding6 小时前
Python 龙与魔法回合制2D游戏m0_617881426 小时前
如何高效进行堆叠分类器的超参数调优:解决 GridSearchCV 卡顿问题编程自留地6 小时前
项目sql语句m0_588758486 小时前
如何高效批量删除SQL数据_使用脚本分段删除降低压力