一、使用mysql数据导出进行备份时,会备份整个表的数据,有时候只想备份一部分数据,这个时候可以使用如下方法:

1. 使用insert into 和 select结合:

  1. insert into talbe_bak(`id`,`name`)
  2. select `id`,`name` from table_data where stat_time >= "2017-08-30" and stat_time < "2017-9-03";

这样会将满足where限制的数据备份到新的table_bak表中。

如果表结构相同:

  1. insert into talbe_bak
    select * from table_original where company_id = 60 and stat_time = "2017-12-30";

如果想备份所有数据:

  1. insert into talbe_bak
    select * from table_original;

2. 使用select into outfile将数据备份到文件:

  1. SELECT `id` INTO OUTFILE "/tmp/result.text" FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n' FROM table_data;

这种方法需要有运行mysql服务的机器的操作权限。部分云端数据库不会提供对运行mysql服务的机器的操作权限,所以这种方法不一定适用。

3. mysqldump -w

  1. mysqldump -u root -p password table_data –-where='stat_time >= "2017-08-30"' > tmp.dump
    mysqldump -h 127.0.0.1 -u test -p <database>  --where="date >= '2018-07-18 00:00:00'"  > /home/zzz/dump.sql # if no table name, dump data of all tables
  2.  
  3. mysqldump -h 127.0.0.1 -u root -pPassword  <database_name>  > ./test_database.sql # add password in command, make it possible to run background
  1. mysqldump -h 127.0.0.1 -u test -p <database> <table> --where="date >= '2018-07-18 00:00:00'"  > /home/zzz/dump.sql # dump data in table indentified by table_name
  2.  
  3. mysqldump --skip-triggers --compact --no-create-info -h 127.0.0.1 -u test -p <database>  --where="date >= '2018-07-18 00:00:00'"  > /home/zzz/dump.sql
  1. mysqldump -u root -p database_name | mysql -h other-host.com database_name # 直接将数据导出到其他服务器
  2.  
  3. # 导入备份数据
    mysql -u root -h 127.0.0.1 -p <database_name> < /backup/mysql_data/test_database.sql
  1. mysqldump -u... -p... mydb t1 t2 t3 > mydb_tables.sql # mydb, t1, t2, t3三张表的数据导出
  1. mysqldump -u USERNAME -pPASSWORD DATABASE --ignore-table=DATABASE.table1 > database.sql

这种方法可以导出远程服务器的数据。

https://dba.stackexchange.com/a/8892/174516  # 导入到不通数据库

二、如果想在两张结构不同的表之间迁移数据,一张表的一部分字段,需要迁移到另一个表:

  1. insert into data_base.destination (start_time, end_time, sales, prices)
    select start_time, end_time, sales, prices from data_base.original;

还可以使用replace into

  1. replace into data_base.destination (start_time, end_time, sales, prices)
  2. select start_time, end_time, sales, prices from data_base.original where start_time > "2017-01-01";

可以使用IGNORE关键字忽略重复:

  1. insert ignore into data_base.destination (start_time, end_time, sales, prices)
  2. select start_time, end_time, sales, prices from data_base.original;

可以使用ON DUPLICATE KEY UPDATE更新

  1. insert into data_base.destination (start_time, end_time, sales, prices)
  2. select start_time, end_time, sales, prices
    from data_base.original
    where start_time > "2017-01-01"
    on duplicate key update start_time=values(start_time), end_time=values(end_time), sales=values(sales), prices=values(prices);

可以只更新一部分字段:

  1. insert into data_base.destination (start_time, end_time, sales, prices)
  2. select start_time, end_time, sales, prices
  3. from data_base.original
  4. where start_time > "2017-01-01"
  5. on duplicate key update start_time=values(start_time), end_time=values(end_time);

此部分ref:https://segmentfault.com/a/1190000002716966

PS:支持跨库,但是不支持跨服务器

mysqldump: https://www.cnblogs.com/chenmh/p/5300370.html

https://dba.stackexchange.com/a/9309/174516

https://stackoverflow.com/a/425172/8025086

mysql 数据备份及数据迁移的更多相关文章

  1. c# Process cmd 执行完回调 Proc_OutputDataReceived mysql mysqldump mysql source备份还原数据

    c# Process 执行完回调 Proc_OutputDataReceived mysql mysqldump mysql source备份还原数据 直接贴代码 前提:mysql5.7 vs2017 ...

  2. mysql 数据备份与数据导入到出

    一.数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异构系统中如Windows. #2. 逻辑备份: 备份的是建表.建库.插入等操作所执行SQL语句,适用于中小型数 ...

  3. 实际使用Elasticdump工具对Elasticsearch集群进行数据备份和数据还原

    文/朱季谦 目录 一.Elasticdump工具介绍 二.Elasticdump工具安装 三.Elasticdump工具使用 最近在开发当中做了一些涉及到Elasticsearch映射结构及数据导出导 ...

  4. Redis数据持久化、数据备份、数据的故障恢复

    1.redis持久化的意义----redis故障恢复 在实际的生产环境中,很可能会遇到redis突然挂掉的情况,比如redis的进程死掉了.电缆被施工队挖了(支付宝例子)等等,总之一定会遇到各种奇葩的 ...

  5. linux下mysql定时备份,数据保存周期一周

    以下脚本来自网络,版权归原作者所有(推荐放在夜间自动备份,用cron制定计划任务) crontab -e 0 3 * * * /var/erp/data/mysql_backup.sh #!/bin/ ...

  6. linux数据误删后,灾难性数据备份与数据还原

    一 准备工作 #rm –rf  误删重要数据怎么办? 1. 要冷静,通知停止该服务器一切操作 2. 查看被删除文件所在分区 #mount 3. 将该分区设置为只读 #mount -r -n -o re ...

  7. MySQL(十四)之数据备份与还原

    前言 上一篇分享了关于MySQL事务的知识,在我们数据库中最重要的就是数据了,所以数据的备份就显的特别的重要! 为什么要备份数据? 在生产环境中我们数据库可能会遭遇各种各样的不测从而导致数据丢失, 大 ...

  8. MySQL-06 数据备份和恢复

    学习目标 数据备份 数据恢复 数据库迁移 导入和导出 数据备份 系统意外崩溃或者服务器硬件损坏都有可能导致数据库丢失,因此生产环境中数据备份非常重要. MySQLdump命令备份 该命令可以将数据库备 ...

  9. NoSQL 数据库案例实战 -- MongoDB数据备份、恢复

    MySQL数据迁移到MongoDB数据库中 前言 一.数据备份 二.数据恢复 前言 本环境是基于 Centos 7.8 系统构建mongodb-enterprise-4.2.8学习环境具体构建,请参考 ...

随机推荐

  1. PythonWeb开发教程(一),开发之前需要准备什么

    什么是web开发呢,其实就是开发一个网站了.那开发网站需要用到哪些知识呢 1.python基础,因为用python开发的,所以python指定要会,最起码你也得会条件判断,循环,函数,类这些知识: 2 ...

  2. 【转】linux下解压.bz2压缩文件

    原文网址:http://zhidao.baidu.com/question/90378903.html tar-c: 建立压缩档案-x:解压-t:查看内容-r:向压缩归档文件末尾追加文件-u:更新原压 ...

  3. 【转】RS232、RS485、TTL电平、CMOS电平

    原文网址:http://blog.sina.com.cn/s/blog_63a0638101018grc.html RS232.RS485.TTL电平.CMOS电平 什么是TTL电平.CMOS电平.R ...

  4. IE 10 如何设置支持CRM4 正常浏览

    通过工具—> 选择兼容性视图 就可以了.具体如下图:

  5. 专访TK教主于旸:原来那些搞安全的说的都是真的(图灵访谈)

    引用:http://www.ituring.com.cn/article/196609 于旸,网名“tombkeeper”,在国内黑客界被尊称为“TK教主”,现任腾讯玄武实验室总监.于旸从事信息安全研 ...

  6. iPhone激活策略说明

    本帖最后由 苏州汇东 于 2014-7-2 19:13 编辑 奉告各位封釉 千万不要泄露机器序列号IMEI号 远程ID真的可以上  只要机器上没有ID 就可以远程上任何ID 我这可以远程上ID 也帮忙 ...

  7. ubuntu 14.04 git clone 出现 fatal: Unable to find remote helper for 'https'

    当你编译安装git时因为没有安装(lib)curl-devel所以导致git clone 和 git push 都会出现这个错误 如果你安装了(lib)curl-devel,然后重新编译安装git就没 ...

  8. Mybatis学习(3)关于mybatis全局配置文件SqlMapConfig.xml

    比如针对我这个项目的mybatis全局配置文件SqlMapConfig.xml做一些说明: <?xml version="1.0" encoding="UTF-8& ...

  9. HDU 1269 迷宫城堡(向量)(Tarjan模版题)

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  10. 软件-分布式:Kylin (apache开源分布式分析引擎软件)

    ylbtech-软件-分布式:Kylin (apache开源分布式分析引擎软件) Apache Kylin™是一个开源的分布式分析引擎,提供Hadoop之上的SQL查询接口及多维分析(OLAP)能力以 ...