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]

相关推荐
Flying pigs~~39 分钟前
RAG智慧问答项目
数据库·人工智能·缓存·微调·知识库·rag
misL NITL1 小时前
mysql之如何获知版本
数据库·mysql
许彰午2 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
2401_832365522 小时前
JavaScript中rest参数(...args)取代arguments的优势
jvm·数据库·python
2301_779622413 小时前
Go语言怎么用信号量控制并发_Go语言semaphore信号量教程【入门】
jvm·数据库·python
2301_766283443 小时前
c++如何将控制台输出保存到文件_cout重定向到txt【详解】
jvm·数据库·python
北极的冰箱3 小时前
MySQL Ver 8.0.41 for macos14.7密码遗忘
数据库·mysql
XDH_CS4 小时前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql
秋94 小时前
MySQL 8.0.46 全平台安装与配置详解(Windows/Linux/macOS)
linux·windows·mysql
treacle田4 小时前
达梦数据库-统计信息收集-记录
数据库·达梦数据库统计信息收集