数据的导入与导出
mysqldump 是一个 MySQL 自带的工具,它可以生成一个包含 CREATE TABLE 和 INSERT 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
如果你只需要备份 users 和 orders 这两个表。
示例 3:仅导出数据库结构(不包含数据)
mysqldump -u root -p --no-data mydatabase > mydatabase_schema.sql
这在需要复制数据库结构到另一个环境时非常有用。
示例 4:导出所有数据库
mysqldump -u root -p --all-databases > all_databases_backup.sql
这个导出的文件会包含 CREATE DATABASE 和 USE 语句,导入时会更方便。
示例 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]