作者:乌鸦bz_371 | 来源:互联网 | 2024-10-11 11:27
概述
这里以一份备份文件50G的文件来恢复,假设要恢复其中一张表,如果做全库恢复不太现实。下面使用正则匹配的方式去把需要恢复的表数据拿出来,然后进行恢复。
注意前两种方法show tables的表顺序要和mysqldump时的顺序相同
先看一下show tables的顺序:
1、基于awk截取顺序恢复
顺序恢复calendar表到zt_dept表
awk '/^-- Table structure for table .calendar./,/^-- Table structure for table .zt_dept./{print}' zentao20200505-233001.sql > /data/t1.sql
2、基于sed截取顺序恢复
顺序恢复calendar表到zt_dept表
cat zentao20200505-233001.sql | sed -n -e '/Table structure for table .calendar./,/Table structure for table .zt_dept./p'> /data/t2.sql
3、基于sed单表恢复sed -n -e '/DROP TABLE.*`calendar`/,/UNLOCK TABLES/p' zentao20200505-233001.sql > /data/t3.sql
最后做数据恢复时直接source /data/tables.sql即可。