场景

昨天系统自动备份了某一个数据库的全部表数据,名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

更多相关文章

  1. 2011.11.25——— android ndk 坑爹的cygwin
  2. Android(安卓)读取doc文件
  3. 如何去掉状态栏和内容视图之间的黑色阴影线
  4. mybatisplus的坑 insert标签insert into select无参数问题的解决
  5. python起点网月票榜字体反爬案例
  6. NPM 和webpack 的基础使用
  7. 【阿里云镜像】使用阿里巴巴DNS镜像源——DNS配置教程
  8. 读取android手机流量信息
  9. android 使用html5作布局文件: webview跟javascript交互

随机推荐

  1. android source code online
  2. 在Android中使用Handler和Thread线程执行
  3. Android ImageView 总结【转载】
  4. Android ImageView图片显示点击背景切换
  5. android退出应用程序解决方案
  6. xmlns:android的作用
  7. Android定时器实现的几种方法
  8. Android 修改开机动画(bootanimation)
  9. Android 支持网络协议以及简单用法
  10. Android 基础知识点(持续更新)