一、使用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. tomcat源码阅读之部署器

    我们知道web应用是用Context实例表示的,而Context是部署到Host实例中的,因此tomcat的部署器是关联的Host实例.Context实例可以用WAR文件部署,也可以把整个web应用的 ...

  2. jquery ajax 上传文件

    html:<!-- /.tab-pane --> <div class="tab-pane" id="head_portrait"> & ...

  3. 51nod 1673 树有几多愁——虚树+状压DP

    题目:http://www.51nod.com/Challenge/Problem.html#!#problemId=1673 建一个虚树. 一种贪心的想法是把较小的值填到叶子上,这样一个小值限制到的 ...

  4. c 结构体的队列

    头文件 lsg_queue.h #pragma once #include<stdbool.h> /* 链式栈接口的定义头文件 */ #define true 1 #define fals ...

  5. 搭建openwrt_x86虚拟机环境

    1.下载源码 http://downloads.openwrt.org/snapshots/trunk/x86/openwrt-x86-generic-combined-ext4.img.gz 2.格 ...

  6. 关于Spring IOC (DI-依赖注入)

    <Spring入门经典>这本书无论对于初学者或者有经验的工程师还是很值一看的,最近花了点时间回顾了Spring的内容,在此顺带记录一下,本篇主要与spring IOC相关 ,这篇博文适合初 ...

  7. visual leak detector用法

    百度vld和windbg安装 配置symbol路径 配置环境变量 _NT_SYMBOL_PATH SRV*E:\symbols*http://msdl.microsoft.com/download/s ...

  8. BASIC-7_蓝桥杯_特殊的数字

    代码示例: #include <stdio.h>#define B(X) (X)*(X)*(X) int main(void){ int i = 0 ; int a = 0 , b = 0 ...

  9. [转]OBJECT_ID 有哪些种类

    本文来自: http://www.cnblogs.com/biwork/archive/2013/01/07/2849311.html 特别是在建表建存储过程的时候进场会写到: IF OBJECT_I ...

  10. 6.15-初识JSP、javaweb

    一.javaweb web服务器 tomcat C/S 客户端/服务器 B/S 浏览器/服务器 URL: http协议 https 加密的协议 localhost 127.0.0.1 常用web服务器 ...