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

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

相关推荐

  • 如何取消定时关机命令?详细操作步骤是什么?

    在日常使用电脑时,我们有时会通过定时关机命令来安排电脑在特定时间自动关闭,比如下载大文件、系统更新或离开办公室时,但若临时需要取消这一计划(如任务提前完成、需紧急使用电脑),掌握取消定时关机命令的方法十分必要,不同操作系统(如Windows、macOS、Linux)的取消方式略有差异,本文将详细讲解各类系统的操……

    2025年8月31日
    5200
  • 安全带卷收器数据规格需关注哪些核心参数?

    安全带卷收器作为汽车被动安全系统的核心部件,其性能直接关系到碰撞事故中乘员的安全防护效果,数据规格是衡量卷收器质量的关键指标,涵盖机械性能、材料特性、环境适应性等多个维度,需严格遵循国内外法规及行业标准(如GB 14166、ECE R16、FMVSS 209等),以下从性能参数、材料规格、环境适应性、测试标准等……

    2025年10月25日
    3400
  • 安全合规折扣如何平衡合规要求与折扣优惠?

    安全合规是企业运营的底线,也是获取市场竞争优势的重要筹码,近年来,随着监管趋严和风险意识提升,越来越多的企业意识到,满足安全合规要求不仅能规避法律风险,还能通过“安全合规折扣”实现降本增效,这种折扣并非简单的价格优惠,而是企业在合规管理、风险控制、标准认证等方面达到特定水平后,获得的多元化激励与回报,覆盖保险……

    2025年10月19日
    3100
  • 低分辨率设备卡顿?3招解决!

    Android wm 命令是 窗口管理器(Window Manager) 的核心工具,主要用于通过 ADB 调试或自动化脚本管理设备的屏幕显示参数(如分辨率、密度、屏幕裁剪等),它属于 Android 系统级命令,需通过 adb shell 执行,通常需要 root 权限,以下是详细使用指南:使用前提开启 US……

    2025年7月24日
    6200
  • HTTP重定向如何安全进行?需规避哪些关键安全风险?

    在互联网安全领域,数据传输的加密与完整性保护至关重要,随着网络安全威胁日益增多,从HTTP(超文本传输协议)向HTTPS(安全超文本传输协议)迁移已成为行业共识,而HTTP重定向作为实现这一迁移的关键技术,其安全性直接关系到网站数据安全、用户体验及搜索引擎优化(SEO),本文将深入探讨如何安全地执行HTTP到H……

    2025年11月19日
    1500

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信