linux中mysql下mysqldump命令常见用法详解

linux中mysql下mysqldump命令常见用法详解

  • 一、导出
    • 1、数据库db级
    • 2、数据表级
    • 3. 主要导出参数
  • 二、 导入
    • 1. 常用导入方法
    • 2. 导入示例
  • 三、 拼出部分对象创建语句
    • 1. 导出视图创建语句
    • 2. 导出其他对象

一、导出

1、数据库db级

导出所有db结构和数据

mysqldump -uroot -p -A > /data/bak/all.sql

仅导出所有db结构

mysqldump -uroot -p -A -d > /data/bak/all_struct.sql

仅导出所有db数据不导表结构

mysqldump -uroot -p -A -t > /data/bak/all_data.sql

导出单个db结构和数据

mysqldump -uroot -p mydb > /data/bak/mydb.sql

仅导出单个db结构

mysqldump -uroot -p mydb -d > /data/bak/mydb.sql

仅导出单个db数据

mysqldump -uroot -p mydb -t > /data/bak/mydb.sql

导出多个db结构和数据(–databases参数,数据,结构单独导出方法同上)

mysqldump -uroot -p --databases db1 db2 > /data/bak/muldbs.sql

2、数据表级

导出指定db某张表结构及数据(数据,结构单独导出方法同上)

mysqldump -uroot -p dbname test > db.sql

导出指定db中多张表(test1,test2,test3)结构及数据

mysqldump -uroot -p dbname test1 test2 test3 > db.sql

排除部分表,导出DB中其余表结构和数据

mysqldump -uroot -p mydb --ignore-table=mydb.test1 --ignore-table=mydb.test2 > /data/bak/mydb.sql

指定where条件导出表的部分数据

mysqldump -uroot -w “name=‘qipa250’” -p db_name tbl_name > /tmp/where.sql

3. 主要导出参数

–all-databases, -A:导出所有数据库
–databases, -B:导出多个数据库。不使用该选项时,mysqldump把第一个名字参数作为db名,后面的作为表名;使用该选项时,则把每个名字都当作为db名。
default-character-set:指定默认字符集,不指定默认为UTF-8
–force, -f:即使发现sql错误,仍然继续导出
–no-data, -d:只导出表结构
–port=port_num, -P port_num:端口号
–quick, -q:强制mysqldump从服务器每次查询一行数据而不是查询整个表。避免大表导出时查询刷爆内存且热点数据被刷出缓冲池,通常建议总是启用该选项。
–tables:覆盖 --databases or -B选项,后面所跟参数被视作表名
–tab=path(-T path):产生TAB分割的数据文件,为每张表建一个包含create table语句的tabname.sql和一个包含数据的tabname.txt文件
–xml, -X:导出为xml文件
–single-transaction:导出开始前先执行start transaction命令,导出时不锁表,仅支持InnoDB存储引擎,需要确保导出时无DDL操作
–lock-tables(-l):导出过程中依次锁住每个schema下所有表(只能保证各schema下表导出的一致性),被锁的表只能读,MyISAM存储引擎常用
–lock-all-tables(-x):导出过程中锁住所有schema下所有表,避免前面参数无法保证所有schema下表导出的一致性的问题,但是所有表都变为只读
–master-data=[value] 主要用于建从库。value=1时,dump文件包含change master语句,导入时自动执行;value=2时,change master语句被注释,需手动执行。–master-data会忽略–lock-tables选项,如果不加–single-transaction选项会自动使用–lock-all-tables
–where(-w):指定导出条件
–events(-E):导出事件调度器
–routines(-R):导出存储过程和函数
–triggers:导出触发器
–hex-blob:将binary,varbinary,blog,bit列类型导出为16进制格式

二、 导入

导入用户需要有执行备份文件中语句的权限(ddl、dml等)。

1. 常用导入方法

系统命令行方法

mysql -uroot -p < test_backup.sql

mysql命令行source方法

mysql -uroot -p

source /home/mysql/test_backup.sql

2. 导入示例

导入所有数据库

mysql命令行:mysql>source /data/bak/all.sql
系统命令行: mysql -uroot -p123456 < /data/bak/all.sql

导入单个数据库

mysql命令行:

mysql>use mydb

mysql>source /data/bak/mydb.sql

系统命令行:

mysql -uroot -p123456 mydb < /data/bak/mydb.sql

导入单个数据库的多个表

mysql命令行:

mysql>use mydb

mysql>source /data/bak/multables.sql

系统命令行:

mysql -uroot -p123456 mydb < /data/bak/multables.sql

导入多个数据库(一个备份文件里有多个数据库的备份,此时不需要指定数据库)

mysql命令行:

mysql>source /data/bak/muldbs.sql

系统命令行:

mysql -uroot -p123456 < /data/bak/muldbs.sql

三、 拼出部分对象创建语句

有时将数据库迁移新环境时,业务方会要求修改新库库名和用户名,如果源库中有视图,存储过程、函数、触发器、事件等对象,导入时会遇到问题,因为这些对象definer中可能会写明了用户,创建语句中指定了库名。

这种情况下,可以先做一次全量导入,然后删掉这些问题对象,再分别用导入创建语句的方式导入这些对象。

1. 导出视图创建语句

创建视图的时候一般会带上库名和definer的定义,如果迁移数据时,目标库的库名、用户名和源库的不一样,则视图迁移会失败。 如果遇到这种情况,需要分2步导出,第1步迁移表数据,第2步迁移视图。

查询出要导的库的全部表

select table_name from information_schema.tables where table_schema='mytest' and table_type!='view';

查询之后,用notepad++替换掉| 和\r 回车,然后mysqldump命令导出

mysqldump --set-gtid-purged=OFF -uroot -p --single-transaction -R --triggers --events --max_allowed_packet=1G mytest T1 T2 T3 T4

导出视图

SELECT CONCAT("CREATE VIEW ",TABLE_NAME," as ",VIEW_DEFINITION,";") FROM information_schema.VIEWS where table_schema='mytest';

如果是同名库的导出可以用下面的语句

SELECT CONCAT("DROP VIEW IF EXISTS `",TABLE_SCHEMA,"`.`",TABLE_NAME,"`;\nCREATE VIEW `", TABLE_SCHEMA,"`.`",TABLE_NAME,"` as ",VIEW_DEFINITION,";") FROM  information_schema.VIEWS where table_schema='mytest';

2. 导出其他对象

一般情况下,-R --triggers --events 可以正常导出存储过程、函数、触发器等信息,但是如果创建的时候也写了definer和库名,需要用下面的方式导出。

查看存储过程

select routine_name,routine_type from information_schema.routines where routine_schema='mytest' and routine_type='PROCEDURE';

查看函数

select routine_name,routine_type from information_schema.routines where routine_schema='mytest' and  routine_type='FUNCTION';  

查看触发器

select trigger_name from information_schema.triggers where trigger_schema="mytest";

查看事件

    select event_name from information_schema.events where event_schema='mytest';

导出存储过程和函数

SELECT CONCAT("DROP ",TYPE," IF EXISTS `",db,"`.`", NAME,"`;\nDELIMITER ;;\nCREATE ",TYPE," `",db,"`.`",NAME,"`(", param_list,") ",IF ( TYPE = "FUNCTION", CONCAT ("RETURNS ", RETURNS, "\n"),"\n"), body_utf8,";;\nDELIMITER ;") FROM  mysql.proc;

导出触发器

SELECT CONCAT("DROP TRIGGER IF EXISTS `",TRIGGER_SCHEMA, "`.`", TRIGGER_NAME,"`;\nDELIMITER ;;\nCREATE TRIGGER `",TRIGGER_SCHEMA,"`.`",TRIGGER_NAME,"` ",ACTION_TIMING," ",EVENT_MANIPULATION," ON `",EVENT_OBJECT_SCHEMA,"`.`",EVENT_OBJECT_TABLE,"` FOR EACH ROW\n",ACTION_STATEMENT,";;\nDELIMITER ;") FROM information_schema.TRIGGERS;

导出事件

SELECT  CONCAT(   "DROP EVENT IF EXISTS `",   EVENT_SCHEMA,   "`.`",   EVENT_NAME,   "`;\nDELIMITER ;;\nCREATE EVENT `",   EVENT_SCHEMA,   "`.`",   EVENT_NAME,   "` ON SCHEDULE EVERY ",   INTERVAL_VALUE,   " ",   INTERVAL_FIELD,   " STARTS '",   STARTS,"'",   IF ( ENDS <>NULL, CONCAT (" ENDS '",ENDS,"'"),""),     " ON COMPLETION ",   ON_COMPLETION,   " ENABLE DO ",   EVENT_DEFINITION,   ";;\nDELIMITER ;"  ) FROM  information_schema.events;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/142866.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络基础导览

入门 一看就懂&#xff0c;原来这就是计算机网络-CSDN博客一看就懂&#xff0c;把“百度”搬回家-CSDN博客 理论基础 以太网数据帧-CSDN博客 扩展 用互联网思维打造物流网&#xff08;别人笑我太疯癫&#xff0c;我把自己当成仙&#xff09;-CSDN博客

玩转ChatGPT:ARIMA模型定制GPT-1.0

一、写在前面 好久不更新咯&#xff01; OpenAI又推出了GPT的一系列重大更新&#xff0c;其中GPTs深得我心啊。 GPTs允许用户创建自定义的ChatGPT版本&#xff0c;以满足自己各种特定需求。其核心理念在于&#xff0c;用户可以为不同的场景和任务创建定制化的ChatGPT。这意味…

2023云计算发展趋势

目录 一、云计算是什么&#xff1f; 二、云计算发展趋势 三、总结 一、云计算是什么&#xff1f; 云计算是一种基于互联网的计算方式&#xff0c;通过网络连接的方式提供计算能力、存储服务、应用程序和数据资源。它通常通过虚拟化技术实现多个计算机资源的池化&#xff0c;…

【NodeJS】Nodejs安装及环境配置

下载安装包 网址&#xff1a;https://nodejs.org/en 安装程序 1.下载完成后&#xff0c;双击安装包&#xff0c;进行安装&#xff0c;一路默认配置 nxet 即可&#xff0c;安装路劲给默认在C盘&#xff0c;或者选择其他位置&#xff0c;当前教程默认C盘 2.下图根据本身的…

会议邀请 | 思腾合力邀您共赴第二十五届高交会(CHTF2023)

2023年11月15-19日&#xff0c;以“激发创新活力 提升发展质量”为主题的「第二十五届中国国际高新技术成果交易会&#xff08;CHTF2023&#xff09;」将在深圳会展中心&#xff08;福田&#xff09;和深圳国际会展中心&#xff08;宝安&#xff09;举办。思腾合力作为行业领先…

新版软考高项试题分析精选(三)

请点击↑关注、收藏&#xff0c;本博客免费为你获取精彩知识分享&#xff01;有惊喜哟&#xff01;&#xff01; 1、项目整体管理要综合考虑项目各个相关过程&#xff0c;围绕整体管理特点&#xff0c;以下说法中&#xff0c;&#xff08; &#xff09;是不正确的。 A.项目的…

java springboot2.7 JSR303与Hibernate进行Bean的数据校验

我们如果对数据能进行格式校验 做个安全检查就会容易很多 其实 各个系统中都必然后拥有数据校验&#xff0c;这也不是新东西 J2EE规范中JSR303就规范定义了一组有关数据校验的API 首先 我们在 pom.xml 中 注入依赖 <dependency><groupId>javax.validation</gr…

SpringEvent事件通知机制

“Spring Event” 是 Spring 框架通过事件驱动的编程模型来处理应用程序中的事件。开发者可以定义自己的事件&#xff0c;然后在应用程序中触发这些事件。Spring 框架提供了用于发布和监听事件的机制&#xff0c;以实现松散耦合的组件间通信。 有两个核心组件&#xff1a; 事…

centos 6.10 安装 tcmalloc

安装 libunwind-1.6.2 下载地址 解压文件 cd libunwind-1.6.2 ./configure make && make install另一种方式 从 github 上下载的项目, 在执行autoreconf -i 时一直报错&#xff0c;libtool 未定义&#xff0c; 要先在当前目录执行 libtoolize&#xff0c;再执行 au…

PostGIS学习教程五:简单的SQL语句

SQL&#xff0c;或"Structured Query Language-结构化查询语言"&#xff0c;是对关系数据库进行查询数据和更新数据的一种方法。 当我们创建第一个数据库时&#xff0c;你已经看到了SQL&#xff1a; SELECT postgis_full_version();查看PostGIS的版本信息。 在前面的…

应届裁员,天胡开局——谈谈我的前端一年经历

应届裁员&#xff0c;天胡开局——谈谈我的前端一年经历 许久没有更新了&#xff0c;最近一个月都在忙&#xff0c;没错&#xff0c;正如题目所说&#xff0c;裁员然后找工作… 这周刚重新上班&#xff0c;工作第二天&#xff0c;感慨良多&#xff0c;记录些什么吧。 去年十…

基于springboot实现学生选课平台管理系统项目【项目源码】计算机毕业设计

基于springboot实现学生选课平台管理系统演示 系统开发平台 在该地方废物回收机构管理系统中&#xff0c;Eclipse能给用户提供更多的方便&#xff0c;其特点一是方便学习&#xff0c;方便快捷&#xff1b;二是有非常大的信息储存量&#xff0c;主要功能是用在对数据库中查询和…

Outlook如何恢复已删除邮件

Outlook如何恢复已删除邮件 操作指引&#xff1a; Outlook客户端恢复最近7天删除的邮件&#xff1a; Outlook客户端要求最新版本&#xff0c;如没有如下选项&#xff0c;建议联机更新windows update 网页邮箱恢复最近7天删除的邮件&#xff1a;

MySQL 社区开源备份工具 Xtrabackup 详解

文章目录 前言1. Xtrabackup 介绍1.1 物理备份与逻辑备份区别1.2 Xtrabackup 系列版本 2. Xtrabackup 部署2.1 下载安装包2.2 二进制部署2.3 程序文件介绍2.4 备份需要的权限 3. Xtrabackup 使用场景3.1 本地全量备份3.2 本地压缩备份3.3 全量流式备份3.3.1 备份到远程主机3.3.…

喷墨打印的简单介绍

喷墨打印是一种常见的打印技术&#xff0c;使用液体墨水将图像或文本喷射到纸张或其他打印材料上。以下是喷墨打印的主要特点&#xff0c;优秀的喷头厂家&#xff0c;应用场景以及未来发展趋势的概述&#xff1a; **喷墨打印的特点&#xff1a;** 1. **高分辨率&#xff1a;**…

0基础学习PyFlink——水位线(watermark)触发计算

在《0基础学习PyFlink——个数滚动窗口(Tumbling Count Windows)》和《0基础学习PyFlink——个数滑动窗口&#xff08;Sliding Count Windows&#xff09;》中&#xff0c;我们发现如果窗口中元素个数没有把窗口填满&#xff0c;则不会触发计算。 为了解决长期不计算的问题&a…

切换为root用户后,conda:未找到命令

问题&#xff1a;切换为root用户后&#xff0c;conda:未找到命令 结论详细用户切换配置路径 结论 问题&#xff1a;切换为root用户后&#xff0c;conda:未找到命令 &#xff08;anaconda&#xff09; 解决&#xff1a;在~/.bashrc配置里增加conda的路径 详细 用户切换 1 切…

Interactive Analysis of CNN Robustness

Interactive Analysis of CNN Robustness----《CNN鲁棒性的交互分析》 摘要 虽然卷积神经网络&#xff08;CNN&#xff09;作为图像相关任务的最先进模型被广泛采用&#xff0c;但它们的预测往往对小的输入扰动高度敏感&#xff0c;而人类视觉对此具有鲁棒性。本文介绍了 Pert…

微信小程序display常用属性和子元素排列方式介绍

wxss中display常用显示属性与css一致&#xff0c;介绍如下&#xff1a; 针对元素本身显示的属性&#xff1a; displayblock&#xff0c;元素显示换行displayinline&#xff0c;元素显示换行&#xff0c;但不可设置固定的宽度和高度&#xff0c;也不可设置上下方向的margin和p…

Python | 机器学习之聚类算法

​&#x1f308;个人主页&#xff1a;Sarapines Programmer&#x1f525; 系列专栏&#xff1a;《人工智能奇遇记》&#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 目录结构 1. 机器学习之聚类算法概念 1.1 机器学习 1.2 聚类算法 2. 聚类算法 2.1 实验目的…