数据库运维-备份还原操作

1.创建student和score表

CREATE TABLE student (
id INT ( 10 ) NOT NULL UNIQUE PRIMARY KEY ,
name VARCHAR ( 20 ) NOT NULL ,
sex VARCHAR ( 4 ) ,
birth YEAR,
department VARCHAR ( 20 ) ,
address VARCHAR ( 50 )
) ;
CREATE TABLE score (
id INT ( 10 ) NOT NULL UNIQUE PRIMARY KEY AUTO_INCREMENT ,
stu_id INT ( 10 ) NOT NULL ,
c_name VARCHAR ( 20 ) ,
grade INT ( 10 )
) ;

2.为student表和score表增加记录

向 student 表插入记录的 INSERT 语句如下:
INSERT INTO student VALUES ( 901 , ' 张老大 ' , ' 男 ' , 1985 , ' 计算机系 ' , ' 北京市海淀区 ' ) ;
INSERT INTO student VALUES ( 902 , ' 张老二 ' , ' 男 ' , 1986 , ' 中文系 ' , ' 北京市昌平区 ' ) ;
INSERT INTO student VALUES ( 903 , ' 张三 ' , ' 女 ' , 1990 , ' 中文系 ' , ' 湖南省永州市 ' ) ;
INSERT INTO student VALUES ( 904 , ' 李四 ' , ' 男 ' , 1990 , ' 英语系 ' , ' 辽宁省阜新市 ' ) ;
INSERT INTO student VALUES ( 905 , ' 王五 ' , ' 女 ' , 1991 , ' 英语系 ' , ' 福建省厦门市 ' ) ;
INSERT INTO student VALUES ( 906 , ' 王六 ' , ' 男 ' , 1988 , ' 计算机系 ' , ' 湖南省衡阳市 ' ) ;
向 score 表插入记录的 INSERT 语句如下:
INSERT INTO score VALUES ( NULL , 901 , ' 计算机 ' , 98 ) ;
INSERT INTO score VALUES ( NULL , 901 , ' 英语 ' , 80 ) ;
INSERT INTO score VALUES ( NULL , 902 , ' 计算机 ' , 65 ) ;
INSERT INTO score VALUES ( NULL , 902 , ' 中文 ' , 88 ) ;
INSERT INTO score VALUES ( NULL , 903 , ' 中文 ' , 95 ) ;
INSERT INTO score VALUES ( NULL , 904 , ' 计算机 ' , 70 ) ;
INSERT INTO score VALUES ( NULL , 904 , ' 英语 ' , 92 ) ;
INSERT INTO score VALUES ( NULL , 905 , ' 英语 ' , 94 ) ;
INSERT INTO score VALUES ( NULL , 906 , ' 计算机 ' , 90 ) ;
INSERT INTO score VALUES ( NULL , 906 , ' 英语 ' , 85 ) ;

3.备份数据库school到/backup目录

复制代码
[root@localhost ~]# mysqldump -u root -p'RedHat@123' --default-character-set=utf8 school > /etc/backup/school.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@localhost ~]# ll /etc/backup/
total 4
-rw-r--r-- 1 root root 3300 Jul 21 08:43 school.sql

4.备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库

复制代码
[root@localhost ~]# mysqldump --add-drop-table -uroot -p'RedHat@123' school > /etc/backup/school1.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
[root@localhost ~]# ll /etc/backup/
total 8
-rw-r--r-- 1 root root 3300 Jul 21 08:57 school1.sql
-rw-r--r-- 1 root root 3300 Jul 21 08:54 school.sql

5.直接将MySQL数据库压缩备份

复制代码
[root@localhost ~]# mysqldump -uroot -pRedHat@123 --all-databases |gzip > /etc/backup/all.sql.gz
mysqldump: [Warning] Using a password on the command line interface can be insecure.

6.备份MySQL数据库某个(些)表。此例备份student表

复制代码
[root@localhost ~]# mysqldump -uroot -pRedHat@123 school student > /etc/backup/school.student.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.

7.同时备份多个MySQL数据库(其他数据库素材自行准备)

复制代码
[root@localhost ~]# mysqldump -uroot -pRedHat@123 -B school my > /etc/backup/school2.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.

8.仅仅备份数据库结构

复制代码
[root@localhost backup]# mysqldump -uroot -pRedHat@123 -d school > /etc/backup/school_str.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.

9.备份服务器上所有数据库

复制代码
[root@localhost backup]# mysqldump -uroot -pRedHat@123 --all-databases > /etc/backup/all_databases.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.

10.还原MySQL数据库

复制代码
[root@localhost backup]# mysql -uroot -pRadHat@123 < /etc/backup/all_databases.sql
mysql: [Warning] Using a password on the command line interface can be insecure.

11.还原压缩的MySQL数据库

复制代码
[root@localhost backup]# gunzip < /etc/backup/all.sql.gz | mysql -uroot -pRedHat@123
mysql: [Warning] Using a password on the command line interface can be insecure.

12.使用xtrabackup 备份数据库

复制代码
[root@localhost ~]# xtrabackup --backup --user=root --password=RedHat@123 --target-dir=/etc/backup/xtr

13.在另外的数据库服务器上还原xtrabackup 备份

14.使用mydumper备份数据库

复制代码
[root@localhost ~]# mydumper -u root -p RedHat@123 -B school -o /etc/backup/

15.使用mydumper恢复数据库

复制代码
[root@localhost backup]# myloader -u root -p RedHat@123 -d /etc/backup/ -o -B school
相关推荐
倔强的石头_18 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神2 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据3 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_3 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡3 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧3 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon3 天前
SQL学习指南——视图
数据库·sql
活宝小娜3 天前
mysql详细安装教程
数据库·mysql·adb