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]

相关推荐
斌味代码2 小时前
MySQL主从延迟根因诊断法
数据库
逆境不可逃3 小时前
高频 SQL 50 题 之 连接篇 1378 1068 1581 197 1661 577 1280 570 1934
数据库·sql
用户5757303346243 小时前
从 SQL 到对象:Prisma 如何成为全栈开发的“降维打击”利器
数据库
三更两点3 小时前
智能代理工具包:MCP vs. Agent Skills vs. AGENTS.md
数据库·人工智能
Chasing Aurora3 小时前
整理常用的开发工具使用问题和小贴士(二)——软件和浏览器
redis·python·mysql·maven
丸辣,我代码炸了3 小时前
PostgreSQL 大数据查询与索引优化核心总结
大数据·数据库·postgresql
等....3 小时前
Redis使用
数据库·redis·mybatis
betazhou3 小时前
记一次Oracle REDO在线日志损坏故障修复
数据库·oracle·redo·ora-00600
一只小bit3 小时前
Redis 初步入门教程:简单介绍和安装配置
数据库·redis·缓存