返回顶部
首页 > 资讯 > 数据库 >mysql实现从导出数据的sql文件中只导入指定的一个表
  • 119
分享到

mysql实现从导出数据的sql文件中只导入指定的一个表

mysql导出数据sql文件导入指定表 2022-05-22 08:05:38 119人浏览 安东尼
摘要

场景 昨天系统自动备份了某一个数据库的全部表数据,名dbAll.sql.gz。文件较大(如40G) 今天因发现某一个表tableA的一条数据存在问题,需核对两条记录的变化。需从dbAll中找回tableA的数据,以便

场景

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

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

操作方案

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

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

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

法1:

perl extract_sql.pl -t mytable -r mydumpfile > mytable.sql

法2:

cat test1db.sql | sed -n ‘/Table structure for table .test1./,/Table structure for table .test2./p'>/tmp/xxx.sql

法3:

awk ‘/Table structure for table .test1./,/Table structure for table .test2./{print}' src_bake_db.sql.gz > targetdb.sql

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

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

如下所示:

mysqldump -uysp -pYspxxx db_name --where="1=1 limit 100" >/mnt/share/paxxx.com/backup.sql

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

mysqldump -h 服务器名 -u 账号名-p 数据库名 --where="true limit 100"> /tmp/supports_launch.sql

PHPmyadmin导出php脚本:

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

以上这篇mysql实现从导出数据的sql文件中只导入指定的一个表就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持自学编程网。

您可能感兴趣的文档:

--结束END--

本文标题: mysql实现从导出数据的sql文件中只导入指定的一个表

本文链接: https://lsjlt.com/news/9943.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作