MySQL是一種常用的關系型數據庫管理系統,支持從各種不同格式的文件進行數據導入。在導入TXT文件時,MySQL默認使用制表符(\t)作為字段分隔符。然而,當TXT文件不使用制表符分隔數據時,需要指定其它分隔符。
在MySQL中,使用LOAD DATA INFILE語句導入TXT文件。在該語句中,可以使用FIELDS TERMINATED BY子句指定字段分隔符。例如,當TXT文件使用逗號(,)分隔數據時,可以如下編寫LOAD DATA INFILE語句:
LOAD DATA INFILE 'data.txt' INTO TABLE mytable FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
在以上代碼中,指定了逗號作為字段分隔符,并使用換行符(\n)作為行結束符。如果TXT文件中的字段值包含逗號,可以使用ENCLOSED BY子句指定該字段被包含在引號(")中。例如:
LOAD DATA INFILE 'data.txt' INTO TABLE mytable FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n';
在MySQL 8.0版本中,還支持在LOAD DATA INFILE語句中使用REGEXP子句指定正則表達式作為分隔符,例如:
LOAD DATA INFILE 'data.txt' INTO TABLE mytable FIELDS TERMINATED BY REGEXP '[[:space:]]+' LINES TERMINATED BY '\n';
在以上代碼中,指定了正則表達式"[[:space:]]+"作為分隔符,表示任何空格字符(包括制表符)均可作為分隔符。
綜上所述,當導入TXT文件時,需要根據文件的實際內容指定合適的分隔符。在MySQL中,可使用FIELDS TERMINATED BY子句指定分隔符,還可使用ENCLOSED BY和REGEXP子句進一步控制導入過程。
上一篇mysql 改表字段