linux个人心得23 (mysql②)

数据的导入与导出

mysqldump 是一个 MySQL 自带的工具,它可以生成一个包含 CREATE TABLEINSERT INTO 等 SQL 语句的 .sql 文件。这个文件就是数据库的 "逻辑备份",因为它包含了重建数据库所需的所有 SQL 命令。

导出的基本语法

mysqldump -u root -p game > game.sql

这是linux上使用的命令,这个-p后也可以直接跟我们的密码,但是不建议这样用,因为直接在上面输入密码会在历史命令里面暴露,所以用如上指令,会进入交互式输入密码界面,这样就可以防止密码暴露

常用导出场景示例

示例 1:导出整个数据库

mysqldump -u root -p mydatabase > mydatabase_backup.sql

这是最常见的操作,备份一个完整的数据库(包括所有表结构和数据)。

示例 2:导出数据库中的特定几个表

mysqldump -u root -p mydatabase users orders > tables_backup.sql

如果你只需要备份 usersorders 这两个表。

示例 3:仅导出数据库结构(不包含数据)

mysqldump -u root -p --no-data mydatabase > mydatabase_schema.sql

这在需要复制数据库结构到另一个环境时非常有用。

示例 4:导出所有数据库

mysqldump -u root -p --all-databases > all_databases_backup.sql

这个导出的文件会包含 CREATE DATABASEUSE 语句,导入时会更方便。

示例 5:生产环境推荐的导出命令

mysqldump -u root -p \
--single-transaction \
--routines \
--triggers \
--master-data=2 \
mydatabase > mydatabase_prod_backup.sql

在对线上业务(特别是使用 InnoDB 存储引擎的)进行备份时,需要考虑数据一致性,并备份存储过程、函数等。

--single-transaction: 在导出开始时创建一个事务。这可以保证在导出期间的数据是一致的快照,并且不会锁住表,对线上业务影响最小(仅对 InnoDB 有效)。

--routines: 导出存储过程和函数。

--triggers: 导出触发器。

--master-data=2: 在备份文件中记录二进制日志(binary log)的位置。这对于设置主从复制(replication)至关重要。

示例 6:导出并压缩·

mysqldump -u root -p mydatabase | gzip > mydatabase_backup.sql.gz

为了节省磁盘空间,通常会将导出的 SQL 文件进行压缩。

导入的基本语法

数据导入就是执行 mysqldump 生成的 .sql 文件,也就是我们导出的文件,内容大差不差

方式一:使用重定向符 < (最常用)

mysql -u 用户名 -p密码 目标数据库名 < 要导入的文件名.sql

相关推荐
ccddsdsdfsdf7 小时前
DBeaver怎么链接mongoDB
数据库·mongodb
丷丩8 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空999 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
TheRouter9 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro9 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
唐青枫10 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
sql·mysql
JAVA面经实录91710 小时前
Hibernate面试题库
数据库·oracle·hibernate
2301_7736436211 小时前
华为云存储实验
网络·mysql·华为云
迷枫71211 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi12 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具