一、导入导出
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,导出,mysqldump,sql,db1 From: https://www.cnblogs.com/Xinenhui/p/16357091.html