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

相关推荐
weelinking3 小时前
【2026】08_Claude与版本控制:Git协作技巧
数据库·人工智能·git·python·数据挖掘·交互·cloudera
黄焖鸡能干四碗7 小时前
固定资产管理系统建设方案和源码(Java源码)
大数据·数据库·人工智能·物联网·区块链
JoneBB8 小时前
ABAP Webservice连接
运维·开发语言·数据库·学习
解决问题no解决代码问题8 小时前
从乱码到脱敏导出:TiDB CSV 导出实战全指南
数据库
scan7248 小时前
智能体多个工具调用
python
未若君雅裁8 小时前
MySQL高可用与扩展-主从复制读写分离分库分表
java·数据库·mysql
2401_867623988 小时前
CSS Flex布局中如何设置子元素间距_掌握gap属性的现代用法
jvm·数据库·python
月落归舟8 小时前
一篇文章了解Redis内存淘汰机制与过期Key清理
数据库·redis·mybatis
即使再小的船也能远航8 小时前
【Python】安装
开发语言·python
weixin_421725268 小时前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言