一、导入导出

1.1、into outfile(只导出数据)

注意:mysql 5.7+版本,secure_file_priv 的值默认为NULL,即不允许导入或导出,需在 /etc/my.cnf 添加  secure_file_priv = '' 或者  secure_file_priv = '指定目录'  ,重启mysql

1.1.1 导出
select * from table_name into outfile 'file_path';

#指定分隔符
select * from table_name into outfile 'file_path' fields terminated by ',';

注意事项:

  • 导出的文件一定是不存在的
  • mysql用户对导出目录要有读写权限
  • 导出的文件默认以\t为字段分隔符 \n为行分隔符
1.1.2 导入
load data infile '文件路径' into table 表名;

#指定分隔符
oad data infile '文件路径' into table 表名 fields terminated by '分隔符';

注意事项:

  • 文件不要放在mysql读不到的地方(注意目录权限)
  • mysql用户对要导入的文件至少要有读的权限(文件权限)
  • 文件名用双引或单引号引起来

二、备份

2.1、mysqldump

2.1.1 简介

mysqldump 是 MySQL 自带的逻辑备份工具。

备份原理是通过协议连接到 MySQL 数据库,将需要备份的数据查询出来,将查询出的数据转换成对应的insert 语句,当我们需要还原这些数据时,只要执行这些 insert 语句,即可将对应的数据还原。

2.1.2 选项
选项 缩写 说明
登录选项:    
-host -h 数据库服务器ip地址
–port -P 服务器端口号
–user -u MySQL 用户名
–password -p MySQL 密码
备份选项:    
-–databases  or  -B   指定要备份的数据库,多个数据库空格隔开
-–all-databases  or  -A   备份所有数据库
–-all-tablespaces  or  -Y   备份所有表
–-add-drop-table   在每个CREATE TABLE语句前添加DROP TABLE语句,防止数据表重名
--no-data  or  -d   不备份数据
-–compact   压缩模式,产生更少的输出
-–comments   添加注释信息
--lock-tables   备份前,锁定数据库表
–-lock-all-tables  or  -x   备份前,锁定所有库表(全备时)
–-no-create-db/–no-create-info   禁止生成创建数据库语句
-–force   当出现错误时仍然继续备份操作
–-default-character-set   指定默认字符集
--flush-logs  or  -F   更新二进制日志文件
-master-data=2   1:每备份一个库就生成一个新的二进制文件(默认);2:生成一个新的二进制文件
--single-transaction   对事务引擎执行热备,获取一致性备份,仅对innodb存储引擎有效
     
-w   相当于-where
2.1.3 导出

导出所有库,表(包含表结构与表数据)

#all.sql默认保存在bin下
库:
mysqldump -u -p --all-databases > all.sql 表:
mysqldump -u -p --databases db1 –-all-tablespaces > all.sql

导出多个库,表

库:
mysqldump -u -p --databases db1 db2 > all.sql 表:
mysqldump -u -p --databases db1 --tables t1 t2 > all.sql

导出单库,表

库:
mysqldump -u -p --databases db1 > all.sql 表:
mysqldump -u -p db1 t1 > all.sql

只导出表结构

mysqldump -u -p -d db1 t1 > all.sql

只导出表数据

mysqldump -u -p -t db1 t1 > all.sql

使用-w指定时间段导出

mysqldump -uroot -pyy123456 -t -w "notify_time > unix_timestamp('2022-04-20') and notify_time < unix_timestamp('2022-05-06')" sre alarm_lists > test2.sql
2.1.4 恢复
库:
mysql -u -p < all.sql 表:
mysql -u -p db1 < all.sql
2.1.5 source(导入大的sql文件)
mysql -u -p -e 'use db1;source all.sql;'
2.1.6 LOCK TABLES

导表的时候可能会报错:mysqldump: Got error: 1044: "Access denied for user 'sre'@'10.84.xxx.226' to database 'db1'" when doing LOCK TABLES

这是因为没有lock table的权限,在命令行加上 --single-transaction 解决

mysqldump --single-transaction -u sre -p -P 33066 -h 10.79.5.xxx db1 alarm_lists > alarm_lists.sql

Mysql--数据的导入导出以及备份的更多相关文章

  1. mysql 数据到 导入导出 总结

    数据库数据的导入和导出受secure_file_priv配置项影响#限制导入导出,null时无法进行数据的导入导出,空时不限制,设置了目录则只能对该目录下的文件进行导入导出show variables ...

  2. 完美转换MySQL的字符集 Mysql 数据的导入导出,Mysql 4.1导入到4.0

    MySQL从4.1版本开始才提出字符集的概念,所以对于MySQL4.0及其以下的版本,他们的字符集都是Latin1的,所以有时候需要对mysql的字符集进行一下转换,MySQL版本的升级.降级,特别是 ...

  3. mysql数据的导入导出

    2017-12-15       一. mysqldump工具基本用法,不适用于大数据备份   1. 备份所有数据库: mysqldump -u root -p --all-databases > ...

  4. Linux下MySql数据的导入导出

    1,每天4点备份mysql数据: 2,为节省空间,删除超过3个月的所有备份数据: 3,删除超过7天的备份数据,保留3个月里的 10号 20号 30号的备份数据: mysqldump -u用戶名 -p密 ...

  5. MySQL数据表格导入导出

    一 初始数据(共6条记录) username userpwd age admin admin 18 root root 18 cat cat 17 dog dog 15 dog1 dog1 15 zh ...

  6. Docker 中 MySQL 数据的导入导出

    Creating database dumps Most of the normal tools will work, although their usage might be a little c ...

  7. MongoDB学习(三)数据导入导出及备份恢复

    这几天想着公司要用MongoDB,自然就要用到数据导入导出,就自己学习了一下. 在Mongo学习(二)中就讲到了在bin目录下有一些工具,本篇就是使用这些工具进行数据的导入导出及备份恢复. 注意:以下 ...

  8. Mysql --学习:大量数据快速导入导出

    声明:此文供学习使用,原文:https://blog.csdn.net/xiaobaismiley/article/details/41015783 [实验背景] 项目中需要对数据库中一张表进行重新设 ...

  9. linux mysql 数据库操作导入导出 数据表导出导入

    linux mysql 数据库操作导入导出 数据表导出导入 1,数据库导入 mysql -uroot -p show databases; create database newdb; use 数据库 ...

  10. SQL Server中bcp命令的用法以及数据批量导入导出

    原文:SQL Server中bcp命令的用法以及数据批量导入导出 1.bcp命令参数解析 bcp命令有许多参数,下面给出bcp命令参数的简要解析 用法: bcp {dbtable | query} { ...

随机推荐

  1. 容器中sh脚本明明存在,为何会报"no such file or directory"的错误?

    小伙伴碰到一起奇怪的事故,从gitlab上拉取的docker镜像项目,在本地开发机上进行docker build后,启动容器会报错如下: exec /app/run.sh : no such file ...

  2. AdaBoost算法解密:从基础到应用的全面解析

    本文全面而深入地探讨了AdaBoost算法,从其基础概念和原理到Python实战应用.文章不仅详细解析了AdaBoost的优缺点,还通过实例展示了如何在Python中实现该算法. 关注TechLead ...

  3. Chrome扩展的核心:manifest 文件(上)

    大家好,我是dom哥.我正在写关于 Chrome 扩展开发的系列文章,感兴趣的可以点个小星星. Chrome 在全球浏览器市场份额独占 6 成,无论是对普通用户还是开发者,都是电脑里的必备利器.Chr ...

  4. SpringBoot设置日志级别

    输出到控制台 logging: # 日志记录到文件中 file: # 指定文件名 name: server.log logback: rollingpolicy: # 指定文件大小 max-file- ...

  5. 2023年度低代码平台企业TOP50榜单公布—以开源起家的JeecgBoot格外亮眼

    近日,中国科学院主管.科学出版社主办的国家级核心期刊<互联网周刊>联合eNet研究院.德本咨询评选的<2023低代码企业50强>榜单正式公布.这一榜单的公布引起了业内外的广泛关 ...

  6. 专业的字节码查看工具——jclasslib

    下载地址: GitHub地址:点击下方蓝色链接即可. https://github.com/ingokegel/jclasslib/releases/download/6.0.4/jclasslib_ ...

  7. ElasticSearch之Analyze index disk usage API

    本API用于分析.统计指定index当前占用的存储空间. 考虑到本特性目前仍然处于预览状态,因此使用方法.参数等可能会发生变化,或者未来也许会被删除. 本API暂时不建议在生产系统中使用. 命令样例如 ...

  8. kubernetes不同pod之间调用(四)

    kubernetes不同pod之间调用(四) k8s系列 源自我工作上的实际场景,记录于此. kubernetes不同服务间的调用.kubernetes不同容器间的调用.kubernetes不同- 今 ...

  9. 国产Geoscene Server 4.0编译SOE总结

    背景:公司一直使用Arcgis Server 10.1.Visual Studio 2010开发SOE功能,随着国产化软件发展大趋势,SOE中的各种分析功能,需要升级到Geoscene Server环 ...

  10. 面试Java时碰到过的那些问题

    项目终于忙完了,难得不加班,但回到家中却不知道干啥,打开自己的云笔记,看到了以前面试时碰到的一些面试题,下面将会把以前面试时被问到的问题都分享出来,下面的题看看小伙伴们可以答的怎样吧 HashMap实 ...