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

相关推荐
GreatSQL6 小时前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_7 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二3 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐4 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横4 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql