mysql实现从导出数据的sql文件中只导入指定的一个表
作者:asdfghzqlj 时间:2024-01-13 11:43:54
场景
昨天系统自动备份了某一个数据库的全部表数据,名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:
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
来源:https://blog.csdn.net/asdfghzqlj/article/details/82461829
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
浅谈flask截获所有访问及before/after_request修饰器
vue车牌搜索组件使用方法详解
![](https://img.aspxhome.com/file/2023/7/130167_0s.jpg)
试了下Golang实现try catch的方法
三分钟学会Sql Server的复制功能[图]
![](https://img.aspxhome.com/file/UploadPic/20087/18/2008718122618221s.gif)
Python之tkinter进度条Progressbar用法解读
![](https://img.aspxhome.com/file/2023/2/133612_0s.jpg)
检测浏览器对事件的支持程度
CentOS 7.4下安装Oracle 11.2.0.4数据库的方法
![](https://img.aspxhome.com/file/2023/0/69370_0s.jpg)
ajax中get和post的说明及使用与区别
Django --Xadmin 判断登录者身份实例
Python中用Spark模块的使用教程
用yum安装MySQLdb模块的步骤方法
oracle 存储过程和函数例子
background-clip/origin一则运用
![](https://img.aspxhome.com/file/UploadPic/20084/15/2008415145225878s.png)
数据安全之MySQL安全的二十三条军规
sqlserver中with(nolock)深入分析
windows支持哪个版本的python
很全面的MySQL处理重复数据代码
Go html/template 模板的使用实例详解
Windows 7下Python Web环境搭建图文教程
![](https://img.aspxhome.com/file/2023/7/71487_0s.png)