mysql如何备份与恢复函数定义_mysql mysqldump导出存储对象

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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
金銀銅鐵14 小时前
[Python] 扩展欧几里得算法
python·数学·算法
Duckdblab15 小时前
DuckDB 性能调优终极指南:打造闪电般的分析体验
python
带派擂总15 小时前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误
python
笃行35017 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行35017 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行35017 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
金銀銅鐵18 小时前
n^5 和 n 的个位数是否总相等?
python·数学
aqi001 天前
15天学会AI应用开发(九)利用Chroma持久化向量数据
人工智能·python·大模型·ai编程·ai应用