数据库教程:mysql实现从导出数据的sql文件中只导入指定的一个表分享

场景

昨天系统自动备份了某一个数据库的全部表数据,名dbAll.sql.gz。文件较大(如40G)

今天因发现某一个表tableA的一条数据存在问题,需核对两条记录的变化。需从dbAll中找回tableA的数据,以便比较该记录。

操作方案

1.将dbAll.sql.gz导入待比较的数据库(临时数据库)中,然后比较tableA。不推介,因为数据量太大,很耗时

2.解压dbAll.sql.gz后,通过Java代码读取dbAll.sql中的关于tableA的CREATE语句及INSERT语句等到文件tableA.sql,然后通过tableA.sql导入临时数据库即可进行比较。

3.参见(没试过):mysqldump导出的是全库alldb.sql导入的时候可不可以只导其中的一个表

法1:

perlextract_sql.pl-tmytable-rmydumpfile>mytable.sql

法2:

cattest1db.sql|sed-n‘/Tablestructurefortable.test1./,/Tablestructurefortable.test2./p’>/tmp/xxx.sql

法3:

awk‘/Tablestructurefortable.test1./,/Tablestructurefortable.test2./{print}’src_bake_db.sql.gz>targetdb.sql

法3说明:将src_bake_db.sql.gz压缩文件中的test1、test2表的数据导出到targetdb.sql中

补充知识:mysql命令行导出整个库里面所有表的前一百条数据

如下所示:

mysqldump-uysp-pYspxxxdb_name–where=”1=1limit100″>/mnt/share/paxxx.com/backup.sql

直接在命令行运行就可以了,不需要登陆mysql客户端。

mysqldump-h服务器名-u账号名-p数据库名–where=”truelimit100″>/tmp/supports_launch.sql

phpmyadmin导出php脚本:

https://local.phpmyadmin.com/export.php

上述就是数据库技术:mysql实现从导出数据的sql文件中只导入指定的一个表分享的全部内容,如果对大家有所用处且需要了解更多关于mysql数据库学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/dtteaching/909086.html

(0)
上一篇 2021年10月23日
下一篇 2021年10月23日

精彩推荐