四十一、MySQL 导入数据
MySQL 数据库系统有三种方式可以导入 MySQL 导出的数据
1、 使用LOADDATA;
2、 使用mysql命令;
3、 使用·mysqlimport·命令;
使用 LOAD DATA 导入数据
MySQL 中提供了 LOAD DATA INFILE 语句插入数据
下面的SQL 语句从当前目录中读取文件 tbl_language.sql ,将该文件中的数据插入到当前数据库的 tbl_language 表中
LOAD DATA LOCAL INFILE 'tbl_language.sql' INTO TABLE tbl_language;
如果指定 LOCAL 关键词,则表明从客户主机上按路径读取文件
如果没有指定,则文件在服务器上按路径读取文件
导入 csv 格式文件
如果需要导入 csv 格式文件,可以明确地在 LOAD DATA语句中指出列值的分隔符 FIELDS 和行尾标记 LINES
两个命令的 FIELDS 和 LINES 子句的语法是一样的,都是可选的
但是如果两个同时被指定,FIELDS 子句必须出现在 LINES 子句之前
如果用户指定一个 FIELDS 子句,它的子句 (TERMINATED BY、[OPTIONALLY] ENCLOSED BY 和 ESCAPED BY) 也是可选的,不过,用户必须至少指定它们中的一个
LOAD DATA LOCAL INFILE 'tbl_language.csv' INTO TABLE tbl_language
-> FIELDS TERMINATED BY ':'
-> LINES TERMINATED BY '\r\n';
LOAD DATA 默认情况下是按照数据文件中列的顺序插入数据的
如果数据文件中的列与插入表中的列不一致,则需要指定列的顺序
如在数据文件中的列顺序是 a,b,c,但在插入表的列顺序为 b,c,a
LOAD DATA LOCAL INFILE 'tbl_language.csv' INTO TABLE mytbl (b, c, a);