一、使用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. 大数据学习资料之SQL与NOSQL数据库

    这几年的大数据热潮带动了一激活了一大批hadoop学习爱好者.有自学hadoop的,有报名培训班学习的.所有接触过hadoop的人都知道,单独搭建hadoop里每个组建都需要运行环境.修改配置文件测试 ...

  2. x86 openwrt虚拟路由代理上网

    一.代理服务器设置 1.下载代理软件CCProxy 6.8 Build 2.设置如下 二.x86 路由设置 1.在/etc目录下编辑profile http_proxy= https_proxy= f ...

  3. java 使用POI读写Excel文件(兼容2003、2007)

    package com.jadyer.demo; import java.io.File; import java.io.FileOutputStream; import java.io.IOExce ...

  4. <<精通正在表达式>> 书评

     IT产业新技术日新月异,令人目不暇给,然而在这其中,真正称得上伟大东西的却寥寥无几.1998年,被誉为“软件世界的爱迪生”,发明了BSD. TCP/IP.csh.vi和NFS的SUN首席科学家Bil ...

  5. BASIC-19_蓝桥杯_完美的代价

    思路(贪心): 1.两边往中间逼近,步数少; 2.单个字符出现时只考虑移动到中间的步数,不做移动,因为这是最后进行,不影响结果; 示例代码: #include <stdio.h>#defi ...

  6. [UE4]蓝图转换成C++代码

    版本:4.12 1.进行如下设置 2.将项目打包出来(任意一平台都行,本文以Windows为例) 3.打包完成后才会在原项目工程中生成蓝图转换成c++的代码 4.如图路径(转换后的代码路径较深所以一步 ...

  7. Nexus3 仓库搭建(基于Docker)

    Nexus Repository OSS 支持的仓库类型 安装方法(使用docker) 命令: sudo docker run -d \ --name nexus3 \ --restart=alway ...

  8. Oracle 某字段值相同的取前几条数据

    rank() over(partition)的使用(转载)   有的时候会遇到这样的问题,我们需要查询一张表,而且要按照业务排序,比如我需要如下的结果: 地区   日期    费用  产品编号   用 ...

  9. javascript 中的函数声明和函数表达式区别

    函数声明格式: function add(a, b) { alert(a+b); } 函数表达式格式: var add = function (a, b) { alert(a+b); } 解析器在向环 ...

  10. delphi WebBrowser的使用方法详解(四)-webbrowser轻松实现自动填表

    webbrowser轻松实现自动填表 步骤如下:  第一步:获取网页 调用Webbrowser 的Navigate系列函数.等待网页装载完成,得到document对象. 在调用 webBrowser. ...