一、使用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. Linux下远程备份、上传工程,重启服务器

    Linux下远程备份.上传工程,重启服务器 Linux服务器实现远程,原项目的备份.删除,新项目上传,以及远程重启服务器!分成一个主shell调用三个shell文件步骤完成.mainsh.sh一次按顺 ...

  2. 阿里巴巴Java开发手册-并发处理

    1. [强制]获取单例对象需要保证线程安全,其中的方法也要保证线程安全.说明:资源驱动类.工具类.单例工厂类都需要注意. 2. [强制]创建线程或线程池时请指定有意义的线程名称,方便出错时回溯.正例: ...

  3. win7 配置微软的深度学习caffe

    win7 配置微软的深度学习caffe   官方下载: https://github.com/Microsoft/caffe 然后 直接修改caffe目录下的windows目录下的项目的props文件 ...

  4. 查看端口 (windows)

    查看端口 netstat -an |findstr

  5. 异步FIFO格雷码与空满

    在传递读写时钟域的指针使用格雷码来传递,如何把二进制转换为格雷码,格雷码是如何判断读空写满呢? 二进制码转换成二进制格雷码,其法则是保留二进制码的最高位作为格雷码的最高位,而次高位格雷码为二进制码的高 ...

  6. 解决Qt Creator编译输出窗口乱码的问题

    设置环境变量LC_ALL为en_US. 附注:将乱码复制到文本编辑器(如Notepad++)后将编码设置为utf-8,可以看到正确的文字. 看样子是编译输出窗口的编码设置出了问题,或者是gcc的输出编 ...

  7. bzoj3295 动态逆序对

    Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数.给1到n的一个排列,按照某种顺序依次删除m个元素,你的任务是在每次删除一个元素之前统计 ...

  8. bzoj2242 计算器

    Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ Z ( mod P )的最小非负整数: 3.给 ...

  9. NB-IOT/LoRa/Zigbee无线组网方案对比

    物联网设备节点组网存在2种组网方式, 无线组网和有线组网. 无线组网我们常见到的有Zigbee,LoRa, NB-IOT等,其中Lora/NB-IOT属于LPWAN技术,LPWAN技术有覆盖广.连接多 ...

  10. maven学习(6)-Maven依赖范围

    一.maven依赖范围: classpath 分为三种:编译classpath , 测试classpath , 运行classpath Scope 选项如下: Compile:编译依赖范围.默认就是c ...