mysql导入导出数据的示例详解 |
大家好,我是景天,本文主要介绍了MySQL 导出和导入数据的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 一、导出数据库MySQL导出数据的主要作用是将数据库中的数据以某种格式(如SQL、CSV等)导出到一个文件中,以便在需要时进行导入或备份 。 导出数据的作用包括但不限于以下几个方面: 数据备份:导出数据可以将数据库中的数据备份到文件中,以防止数据丢失或意外删除 。 (一)使用SELECT … INTO OUTFILE语句将某个表中的数据导出SELECT … INTO OUTFILE语句是MySQL中用于将查询结果导出为CSV文件的方法 。它允许您将查询结果保存到指定的文件路径中,以便进行后续处理或备份 。 我们有一个名为"students"的表格,其中包含班级、男生人数、女生人数 。要导出这些数据到一个CSV文件中,可以使用以下语句: select * into outfile '/data/file.csv' FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY ' ' from students; 这将导出"students"表中的所有数据,并将其保存到指定路径的CSV文件中 。文件中的每行代表一个用户,每个字段用逗号分隔,并用双引号包围 。 参数说明:
注意事项:
执行这句可能会报错如下 【1】分析原因 其实原因很简单,因为在安装MySQL的时候限制了导入与导出的目录权限 。只允许在规定的目录下才能导入 。 可以通过以下命令查看secure-file-priv当前的值是什么 SHOW VARIABLES LIKE "secure_file_priv"; mysql8.0默认目录是/var/lib/mysql-files/ 可以看到,本地value的值为/var/lib/mysql-files/ 。经查资料,value的值有可能有如下几种: (2)如果value值有文件夹目录,则表示只允许该目录下文件(PS:测试子目录也不行) 。 (3)如果为空,则表示不限制目录 。 【2】解决方案 去掉导入的目录限制 。可修改mysql配置文件(Windows下为my.ini, Linux下的/etc/my.conf),在[mysqld]下面,查看是否有: secure_file_priv = 如上这样一行内容,如果没有,则手动添加 。如果存在如下行: secure_file_priv = /home 这样一行内容,表示限制为/home文件夹 。而如下行: secure_file_priv = 这样一行内容,表示不限制目录,等号一定要有,否则mysql无法启动 。 重启数据库 systemctl restart mysqld.service 默认只能指定 /tmp目录 。否则回报 “ ERROR 1 (HY000) at line 1: Can’t create/write to file ‘/xxxx/xxxx/xxx.csv’ (Errcode: 13)” 错误 !导致原因是因为权限问题,修改起来比较麻烦 !可以放到/tmp/目录下,然后cp到其它你想存放的目录 。【推荐使用这种方法】 导出到tmp/目录成功 下载到本地打开 (二)使用mysqldump工具导出数据mysqldump是MySQL数据库的一个命令行工具,用于备份和导出数据库、表格和数据 。以下是使用mysqldump工具导出数据的基本语法: mysqldump -u username -p dbname table_name > /path/to/output/file.sql 参数说明
导出整个数据库可以使用如下命令: 导出单个数据库结构和数据: mysqldump -uroot -pJxxxxxx357@ --databases db005 >dump2.sql 导出单个数据库中单个表结构和数据: 数据库名 表名 mysqldump -uroot -pJixxxxxxx7@ db005 t1 >dump3.sql 导出整个数据库结构(不包含数据): mysqldump -h localhost -uroot -p123456 -d database > dump.sql 只包含数据库和表结构,不包含数据 mysqldump -uroot -pJinghao31357@ -d db001 >dump.sql 导出单个数据表结构(不包含数据): mysqldump -h localhost -uroot -p123456 -d database table > dump.sql 导出全部数据库数据: mysqldump -uroot -p --all-databases > alldb.sql (三)导出步骤1.原服务器操作1.指定到处对应的数据库文件 mysqldump -uroot -pJinghao31357@ --all-databases --single-transaction > `date +%Y%m%d%H`-mysal-all.sql –single-transaction :让整个数据在dump过程中保证数据的一致性,这个选项对InnoDB的数据表很有用,且不会锁表 。 备份指定数据库指定表(多个表以空格间隔) mysqldump -uroot -p mysql db event > /backup/mysqldump/2table.sql 导出特定数据库的所有表格的表结构及其数据,添加“–databases ”命令参数 mysqldump -u b_user -h 101.3.20.33 -p'H_password' -P3306 --databases test > all_database.sql -A = --all-databases 全库备份-B = --databases 部分库备份 2.将备份的sql语句scp到指定服务器scp 2020081222-maysl-all.sql root@10.0.0.51:/root/ 2.新服务器导入原来的数据库 这种方式不用登录数据库 mysql -uroot -pJinghao31357@ < 2020081222-maysl-all.sql 二、导入数据(一)load data参数详解在MySQL中,您可以使用LOAD DATA语句将外部数据文件导入到数据库中 。LOAD DATA语句允许您以高效的方式将大量数据快速加载到数据库表中 。 以下是使用LOAD DATA导入数据的基本语法: LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name' [REPLACE | IGNORE] INTO TABLE table_name [CHARACTER SET charset_name] [{FIELDS | COLUMNS} [TERMINATED BY 'string'] [[OPTIONALLY] ENCLOSED BY 'char'] [ESCAPED BY 'char'] ] [LINES [STARTING BY 'string'] [TERMINATED BY 'string'] ] [IGNORE number {LINES | ROWS}] [(column_name_or_user_var,...)] [SET column_name = expr,...] 逐个解释这些选项的含义:
导入案例: (二)执行导入load data infile '/tmp/file.csv' into table students FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY ' '; 查看数据库,导入成功 到此这篇关于mysql导入导出数据的示例详解的文章就介绍到这了,更多相关mysql导入导出数据内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持! |