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

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

相关推荐

  • 无图形界面如何管理网络连接?

    基础概念设备(Device):物理或虚拟网络接口(如eth0、wlan0),连接(Connection):配置文件的集合(如IP地址、DNS),可激活在设备上,一个设备可绑定多个连接,但同一时间仅一个激活,状态查看:nmcli device status # 查看设备状态nmcli connection sho……

    2025年7月27日
    11900
  • 如何通过命令查看内存频率?具体操作步骤是什么?

    内存频率是衡量内存性能的重要指标,它直接影响数据传输速度和系统整体响应能力,无论是进行硬件升级、性能优化,还是排查兼容性问题,准确查看当前内存的实际运行频率都至关重要,本文将详细介绍在不同操作系统下,如何通过命令行工具查看内存频率,并解释相关注意事项,Windows系统下查看内存频率的命令在Windows系统中……

    2025年8月30日
    10700
  • 国内dns解析为何如此重要?其作用和影响有哪些?

    国内DNS解析将域名转为IP地址,保障访问速度与稳定性,连接用户与网站,提升体验并保障网络安全。

    2026年2月28日
    3100
  • Node命令行怎么打开?新手必看操作指南

    Node.js作为一款基于Chrome V8引擎的JavaScript运行时,让开发者能够脱离浏览器环境运行JavaScript代码,广泛应用于后端开发、工具链构建、自动化脚本等领域,要使用Node.js,首先需要掌握如何在命令行(也称为终端、Shell)中打开并运行它,本文将从准备工作、不同操作系统下的命令行……

    2025年8月25日
    10700
  • 安全帽数据集具体包含哪些安全帽属性与检测场景的数据?

    安全帽数据集是人工智能领域用于训练、验证和优化安全帽检测算法的核心资源,其通过系统化采集与标注各类场景下佩戴安全帽的图像、视频及关联元数据,为智能安全监控、工业生产防护、交通管理等场景提供技术支撑,随着安全生产要求的提升和计算机视觉技术的普及,高质量安全帽数据集的构建与应用已成为推动智能安防落地的重要基础,数据……

    2025年11月16日
    5800

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信