Mysql--数据的导入导出以及备份
一、导入导出
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--数据的导入导出以及备份的更多相关文章
- mysql 数据到 导入导出 总结
数据库数据的导入和导出受secure_file_priv配置项影响#限制导入导出,null时无法进行数据的导入导出,空时不限制,设置了目录则只能对该目录下的文件进行导入导出show variables ...
- 完美转换MySQL的字符集 Mysql 数据的导入导出,Mysql 4.1导入到4.0
MySQL从4.1版本开始才提出字符集的概念,所以对于MySQL4.0及其以下的版本,他们的字符集都是Latin1的,所以有时候需要对mysql的字符集进行一下转换,MySQL版本的升级.降级,特别是 ...
- mysql数据的导入导出
2017-12-15 一. mysqldump工具基本用法,不适用于大数据备份 1. 备份所有数据库: mysqldump -u root -p --all-databases > ...
- Linux下MySql数据的导入导出
1,每天4点备份mysql数据: 2,为节省空间,删除超过3个月的所有备份数据: 3,删除超过7天的备份数据,保留3个月里的 10号 20号 30号的备份数据: mysqldump -u用戶名 -p密 ...
- MySQL数据表格导入导出
一 初始数据(共6条记录) username userpwd age admin admin 18 root root 18 cat cat 17 dog dog 15 dog1 dog1 15 zh ...
- Docker 中 MySQL 数据的导入导出
Creating database dumps Most of the normal tools will work, although their usage might be a little c ...
- MongoDB学习(三)数据导入导出及备份恢复
这几天想着公司要用MongoDB,自然就要用到数据导入导出,就自己学习了一下. 在Mongo学习(二)中就讲到了在bin目录下有一些工具,本篇就是使用这些工具进行数据的导入导出及备份恢复. 注意:以下 ...
- Mysql --学习:大量数据快速导入导出
声明:此文供学习使用,原文:https://blog.csdn.net/xiaobaismiley/article/details/41015783 [实验背景] 项目中需要对数据库中一张表进行重新设 ...
- linux mysql 数据库操作导入导出 数据表导出导入
linux mysql 数据库操作导入导出 数据表导出导入 1,数据库导入 mysql -uroot -p show databases; create database newdb; use 数据库 ...
- SQL Server中bcp命令的用法以及数据批量导入导出
原文:SQL Server中bcp命令的用法以及数据批量导入导出 1.bcp命令参数解析 bcp命令有许多参数,下面给出bcp命令参数的简要解析 用法: bcp {dbtable | query} { ...
随机推荐
- 最小的k个数 (3.20 leetcode每日打卡)
输入整数数组 arr ,找出其中最小的 k 个数.例如,输入4.5.1.6.2.7.3.8这8个数字,则最小的4个数字是1.2.3.4. 示例 1: 输入:arr = [3,2,1], k = 2 输 ...
- MySQL大表设计
存储大规模数据集需要仔细设计数据库模式和索引,以便能够高效地支持各种查询操作.在面对数亿条数据,每条数据包含数百个字段的情况下,以下是我能想到的在设计数据库的时候需要注意的内容,不足之处欢迎各位在评论 ...
- Vue05-Vuex
01. 什么是状态管理 在开发中,我们的应用程序需要处理各种各样的数据,这些数据需要保存在我们应用程序的某一个位置,对于这些数据的管理我们就称之为 状态管理. 在Vue开发中,我们使用组件化的开发方式 ...
- 如何将IPv4升级到IPv6?看完你就明白了
引言: 随着互联网的快速发展,IPv4(Internet Protocol version 4)已经无法满足日益增长的设备和用户数量的需求. IPv6(Internet Protocol versio ...
- GHOST 系统安装教程 轻松一键,系统恢复到最佳状态
硬盘安装系统 安装前准备 1.保证能够正常进入系统: 2.下载Ghost系统镜像文件: 3.下载镜像安装器: 安装步骤 1.下载Ghost系统镜像"Win7_x64_Pure_5.07.GH ...
- MVC:开发模式
1.jsp演变历史 1.早期只有servlet,只能使用response输出标签数据,非常麻烦. 2.后来有了jsp,简化了Servlet的开发,如果过度使用jsp中即写大量的Ja ...
- 第一行代码 Android 第三版读后感
<第一行代码Android 第三版>是一本非常好的Android开发入门书籍.本书结合作者的丰富经验和实际案例,通过一步一步的介绍,详细地讲解了Android开发的各个方面,包括Andro ...
- windows查看GPU信息(nvidia-smi)
一般在使用windows系统的电脑时,想要了解GPU的使用情况时,我们通常会打开任务管理器去查看.但是这种方式一般只能看到简单的情况.那么我们想要了解更多的情况的话,该怎么办呢.可以在cmd中输入nv ...
- 【scikit-learn基础】--『预处理』之 离散化
数据的预处理是数据分析,或者机器学习训练前的重要步骤.通过数据预处理,可以 提高数据质量,处理数据的缺失值.异常值和重复值等问题,增加数据的准确性和可靠性 整合不同数据,数据的来源和结构可能多种多样, ...
- 为什么在使用onnxruntime-gpu下却没有成功调用GPU?
20240105,记. 最近在使用GPU对onnx模型进行加速过程中(仅针对N卡,毕竟也没有别的显卡了..),遇到了点问题:就是明明在安装了合适版本的显卡驱动和CUDA后,onnx还是不能够成功调用G ...