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

1. 使用insert into 和 select结合:

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

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

如果表结构相同:

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

如果想备份所有数据:

insert into talbe_bak 
select * from table_original;

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

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

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 mysqldump -h 127.0.0.1 -u root -pPassword  <database_name>  > ./test_database.sql # add password in command, make it possible to run background
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

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
mysqldump -u root -p database_name  | mysql -h other-host.com database_name   # 直接将数据导出到其他服务器

# 导入备份数据
mysql -u root -h 127.0.0.1 -p <database_name> < /backup/mysql_data/test_database.sql
mysqldump -u... -p... mydb t1 t2 t3 > mydb_tables.sql   # mydb, t1, t2, t3三张表的数据导出
mysqldump -u USERNAME -pPASSWORD DATABASE --ignore-table=DATABASE.table1 > database.sql

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

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

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

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

还可以使用replace into

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

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

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

可以使用ON DUPLICATE KEY UPDATE更新

insert into data_base.destination (start_time, end_time, sales, prices)
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);

可以只更新一部分字段:

insert into data_base.destination (start_time, end_time, sales, prices)
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);

此部分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. nyoj 魔法少女

    魔法少女 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 前些时间虚渊玄的巨献小圆着实火了一把. 在黑长直(小炎)往上爬楼去对抗魔女之夜时,她遇到了一个问题想请你帮忙. 因为 ...

  2. 00.嵌入式Linux开发环境搭建

     3.虚拟机上网配置 虚拟机如果要从网上获取资源,就要能够访问外网.虚拟机有三种上网方式:桥接上网,NAT上网,单主机模式[没用过].本节从原理和操作2个方面讲了NAT方式和桥接方式这2种不同的虚拟机 ...

  3. tomcat源码阅读之生命周期(LifeCycle)

    一.事件机制流程: 1.     当外部事件源发生事件(比如点击了按钮,数据发生改变更新等)时,事件源将事件封装成事件对象Event: 2.     将事件对象交由对应的事件派发器Dispatcher ...

  4. 【转】每天一个linux命令(4):mkdir命令

    原文网址:http://www.cnblogs.com/peida/archive/2012/10/25/2738271.html linux mkdir 命令用来创建指定的名称的目录,要求创建目录的 ...

  5. Json之语法

    JSON 文本格式在语法上与创建 JavaScript 对象的代码相同. 由于这种相似性,无需解析器,JavaScript 程序能够使用内建的 eval() 函数,用 JSON 数据来生成原生的 Ja ...

  6. window下安装两个mysql服务

    产生这个想法主要是因为win系统之前装了mysql,服务名为mysql.又重新安装xampp,导致mysql冲突,xampp中的mysql始终启动不起来.   解决方法如下: 1.修改xampp中my ...

  7. 4G的添加

    (ZTE 中兴 ME3760_V2 ) 1. 复制myLte文件到相关目录,设置权限为755 2.修改openwrt1407/package/base-files/files/etc/rc.local ...

  8. 【linux】Linux软连接和硬链接

    1.Linux链接概念 Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link).默认情况下,ln命令产生硬链接. [硬连接] 硬连接指通过索引 ...

  9. yum下载文件的存放位置

    yum下载文件的存放位置    默认是: /var/cache/yum 也可以在 /etc/yum.conf 指定 cachedir=/var/cache/yum #存放目录keepcache=1 # ...

  10. 关于WCF

    凡是被DataMember声明修饰的属性,必须要有get和set访问器,靠靠靠!!!! 给接口加 XmlSerializerFormat 强制用xml序列化.