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

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

相关推荐

  • 3D模型太薄?壳命令如何快速加厚度?

    壳命令是3D建模中为曲面或薄壁实体模型添加厚度的关键工具,它通过移除模型的内部材料,创建具有指定均匀厚度的空心结构,常用于制作容器、外壳等需要壁厚的模型。

    2025年7月25日
    2.3K00
  • auto.js如何实现自动点击功能?

    在移动自动化测试、重复性任务处理等场景中,Auto.js凭借其基于JavaScript的脚本能力和无需Root的优势,成为许多开发者和用户的首选工具,“自动点击”是最基础也最核心的功能之一,本文将详细介绍Auto.js实现自动点击的原理、方法及进阶技巧,帮助读者快速掌握这一功能,Auto.js自动点击的核心原理……

    2025年12月13日
    5600
  • 人工智能将如何重塑未来?

    人工智能(Artificial Intelligence,简称AI)作为21世纪最具变革性的技术之一,正在深刻重塑人类社会的生产方式和生活方式,从智能手机中的语音助手到自动驾驶汽车,从医疗诊断中的影像识别到金融风控中的智能分析,人工智能的应用场景已渗透到各行各业,成为推动社会进步的核心驱动力,本文将从人工智能的……

    2025年12月6日
    4400
  • 如何用AT指令访问网络?

    在移动通信和物联网领域,AT指令集是一种广泛应用于调制解调器、嵌入式模块的标准化命令语言,用于控制设备功能、配置参数及执行数据交互,通过AT指令实现网络访问是许多通信场景的核心需求,尤其在工业控制、远程监控、智能表计等需要轻量化网络连接的场合,本文将系统介绍AT指令访问网络的原理、常用指令、配置流程及注意事项……

    2025年12月13日
    3700
  • cad命令窗口怎么打开

    AutoCAD中,可通过输入快捷键“Ctrl + 9”来

    2025年8月10日
    10100

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信