怎样完整导出数据库?轻松保留结构和数据!

MySQL/MariaDB 数据库导出

使用 mysqldump 工具

# 示例:导出名为 `web_data` 的数据库
mysqldump -u root -p123456 --databases web_data > web_backup_full.sql

导出单张表

mysqldump -u root -p123456 web_data users > users_table.sql

仅导出结构或数据

# 仅导出表结构(不含数据)
mysqldump -u root -p123456 --no-data web_data > schema_only.sql
# 仅导出数据(不含结构)
mysqldump -u root -p123456 --no-create-info web_data > data_only.sql

压缩导出结果

mysqldump -u root -p123456 web_data | gzip > web_data_backup.sql.gz

PostgreSQL 数据库导出

使用 pg_dump 工具

# 导出整个数据库(自定义格式,支持压缩)
pg_dump -U [用户名] -F c -f backup.dump [数据库名]
# 示例:导出 `app_db` 到自定义压缩文件
pg_dump -U postgres -F c -f app_backup.dump app_db

导出为纯SQL文本

pg_dump -U postgres app_db > app_backup.sql

导出单张表

pg_dump -U postgres -t users app_db > users_table.sql

SQLite 数据库导出

# 导出整个数据库为SQL文件
sqlite3 my_database.db .dump > backup.sql
# 导出单张表
sqlite3 my_database.db "SELECT * FROM users;" > users_data.csv

MongoDB 数据库导出

# 导出整个数据库(二进制BSON格式)
mongodump --db [数据库名] --out /backup/path
# 示例:导出 `analytics` 到当前目录
mongodump --db analytics
# 导出为JSON(使用 `mongoexport`)
mongoexport --db analytics --collection logs --out logs.json

关键注意事项

  1. 权限与安全

    • 避免在命令中明文写密码(如 -p123456),推荐交互式输入密码或使用配置文件(如 ~/.my.cnf)。
    • chmod 限制备份文件权限(chmod 600 backup.sql)。
  2. 备份验证

    • 检查导出文件是否非空:ls -lh backup.sql
    • 测试导入:mysql -u root -p test_db < backup.sql(MySQL示例)
  3. 自动化备份
    结合 cron 定时任务实现每日备份:

    # 编辑cron任务
    crontab -e
    # 添加以下行(每天2点备份MySQL)
    0 2 * * * mysqldump -u root -p[密码] web_data | gzip > /backups/web_data_$(date +\%F).sql.gz
  4. 存储与版本控制

    • 备份文件命名加入日期:backup_$(date +\%Y\%m\%d).sql
    • 使用云存储(如 AWS S3)或异地服务器保存副本。

常见问题解决

  • 错误:mysqldump: command not found
    安装客户端:

    # Debian/Ubuntu
    sudo apt install mysql-client
    # CentOS/RHEL
    sudo yum install mysql
  • PostgreSQL 权限拒绝
    检查 pg_hba.conf 文件,确保本地连接权限为 trustmd5

  • 导出文件损坏
    gzip -t backup.sql.gz 验证压缩文件完整性。


命令行导出数据库是Linux环境的核心技能,通过 mysqldumppg_dump 等工具可灵活控制备份范围与格式,关键步骤包括:

  1. 选择正确的导出命令和参数;
  2. 保护敏感信息(如密码);
  3. 定期验证备份可用性;
  4. 制定自动化策略保障数据安全。

引用说明:本文操作基于MySQL 8.0、PostgreSQL 14、SQLite 3、MongoDB 5.0的官方文档,具体参数以实际版本为准,参考来源:

  • MySQL Official Documentation: mysqldump
  • PostgreSQL Docs: pg_dump
  • SQLite CLI Guide
  • MongoDB Backup Methods

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/8380.html

(0)
酷番叔酷番叔
上一篇 3天前
下一篇 3天前

相关推荐

  • Windows下如何用CMD一次执行多条命令?

    方法1:顺序执行(&)用 & 连接命令,无论前一个命令是否成功,后续命令都会执行,示例:echo 第一条命令 & echo 第二条命令输出:第一条命令第二条命令适用场景: 批量执行无依赖关系的任务(如清理缓存后启动程序),方法2:条件执行(&& 和 ||)&&am……

    2025年6月30日
    1500
  • CAD光标为何不显示命令提示?

    核心原因与解决方案动态输入(Dynamic Input)被关闭原理:动态输入(状态栏图标: DYN)允许命令提示和坐标输入直接显示在光标附近,关闭后,信息仅显示在底部命令行,解决方法:按下快捷键 F12 切换动态输入状态(最常用),点击CAD界面底部状态栏的 DYN 按钮,确保其亮起(蓝色/绿色),命令行窗口被……

    2025年6月21日
    1400
  • 如何找回MySQL执行过的SQL命令?

    通过客户端历史记录文件查询MySQL命令行客户端(如mysql)会自动记录执行过的命令,保存在用户主目录的隐藏文件中:定位历史文件:Linux/macOS:~/.mysql_historyWindows:C:\Users\<用户名>\.mysql_history(需开启显示隐藏文件)查看历史命令:直……

    2025年7月9日
    1400
  • 如何高效使用SVN命令行?

    环境准备安装验证打开终端(Windows:CMD/PowerShell;macOS/Linux:Terminal),输入: svn –version若显示版本信息(如 svn, version 1.14.2),则安装成功,核心概念仓库(Repository):中央存储所有版本数据的服务器(如 https……

    2025年7月9日
    1300
  • Linux用户组创建,命令行如何秒懂权限管理?

    核心命令:groupadd基础语法sudo groupadd [选项] 组名操作示例创建名为 developers 的用户组:sudo groupadd developers关键选项指定 GID(组ID)-g 选项自定义组ID(避免与系统保留ID 0-999冲突):sudo groupadd -g 1500 t……

    2025年7月12日
    1300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信