mysql-f--force_四⼗⼀、MySQL导⼊数据
MySQL 数据库系统有三种⽅式可以导⼊ MySQL 导出的数据
1、 使⽤ LOAD DATA
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);
使⽤ mysqlimport 导⼊数据
mysqlimport 命令是 LOAD DATA INFILE 语句的⼀个命令⾏接⼝
mysqlimport 的⼤多数选项直接对应 LOAD DATA INFILE ⼦句
使⽤下⾯的命令将数据从⽂件 中导⼊到 souyunku 数据中
mysqlimport -u root -p --local souyunku
mysqlimport 命令可以指定选项来设置指定格式
mysqlimport -u root -p --local --fields-terminated-by=":" \
--lines-terminated-by="\r\n" souyunku
mysqlimport 语句中使⽤ --columns 选项来设置列的顺序
mysqlimport -u root -p --local --columns=b,c,a souyunku
mysqlimport 命令的常⽤选项
选项
功能
-d
–delete
新数据导⼊数据表中之前删除数据数据表中的所有信息
-f
–force
不管是否遇到错误,mysqlimport将强制继续插⼊数据
-i
–ignore
mysqlimport跳过或者忽略那些有相同唯⼀
关键字的⾏, 导⼊⽂件中的数据将被忽略。
-l
-lock-tables
数据被插⼊之前锁住表,这样就防⽌了,
你在更新数据库时,⽤户的查询和更新受到影响。
-r
-replace
这个选项与-i选项的作⽤相反;此选项将替代
表中有相同唯⼀关键字的记录
–fields-enclosed-by= char
指定⽂本⽂件中数据的记录时以什么括起的, 很多情况下
数据以双引号括起。 默认的情况下数据是没有被字符括起的。–fields-terminated-by=char
指定各个数据的值之间的分隔符,在句号分隔的⽂件中,
分隔符是句号。您可以⽤此选项指定数据之间的分隔符。
默认的分隔符是跳格符(Tab)
–lines-terminated-by=str
此选项指定⽂本⽂件中⾏与⾏之间数据的分隔字符串import语句
或者字符。 默认的情况下mysqlimport以newline为⾏分隔符。您可以选择⽤⼀个字符串来替代⼀个单个的字符:
⼀个新⾏或者⼀个回车
⼲货推荐
附录:MySQL 教程:系列⽂章

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。