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

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)
酷番叔酷番叔
上一篇 2025年7月23日 21:34
下一篇 2025年7月23日 21:43

相关推荐

  • 如何用快捷键最快捷完成?

    快捷键通过组合键快速执行操作,提升效率减少鼠标依赖,掌握常用组合如复制粘贴,可大幅节省时间优化工作流程。

    2025年8月9日
    17500
  • 云计算与管理,国内哪家更胜一筹?

    阿里云综合实力最强,市场占有率最高;华为云在政企服务领域优势显著。

    2026年2月7日
    7100
  • Windows 8如何快速打开命令提示符?

    Windows 8 提供多种可靠方式打开命令提示符:通过开始按钮右键菜单、搜索功能、运行对话框或文件资源管理器地址栏;需管理员权限时选择对应选项即可。

    2025年7月27日
    16300
  • 安全与便利,人脸识别如何平衡?

    人脸识别技术之辨随着人工智能技术的飞速发展,人脸识别已从实验室走向日常生活,广泛应用于门禁系统、支付验证、公共安全等领域,这项技术通过捕捉和分析面部特征,实现了身份核验的自动化与高效化,极大地提升了便利性,其广泛部署也引发了关于数据安全、隐私侵犯和伦理风险的争议,如何在享受技术红利的同时,平衡安全与便利,成为社……

    2025年11月26日
    11200
  • AT指令如何连接远程服务器?

    在物联网和嵌入式系统开发中,设备与远程服务器的通信是核心功能之一,AT指令作为一种通用的控制命令集,因其简单高效而被广泛应用于模块化通信(如GPRS、4G/5G模块)中,实现设备通过移动网络或以太网连接远程服务器,本文将详细介绍AT指令连接远程服务器的流程、关键指令及注意事项,帮助开发者快速掌握这一技术,AT指……

    2025年12月13日
    11800

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信