以不同的日期格式将 CSV 导入 MySQL

2022-01-09 00:00:00 csv insert mysql

我第一次将 CSV 导入 MySQL,发现 CSV 中的日期格式为 31-Jan-2011.如何将其转换为 2011-01-31 以便将其放入 DATE 数据类型中?首先想到的是让 PHP 进行转换,然后将其插入到第二个表中,但我猜那是……不对.

I'm doing my first CSV import into MySQL and noticed that the date in the CSV has the format 31-Jan-2011. How can I convert this to 2011-01-31 so I can place it in the DATE datatype? The first thing which came to mind is let PHP do the conversion then insert it into a 2nd table but I'm guessing that's...not right.

推荐答案

从CSV文件导入数据时可以替换格式,例如-

You can replace format during importing data from the CSV file, for example -

LOAD DATA INFILE 'file_name.csv'
INTO TABLE table_name
FIELDS TERMINATED BY ';'
LINES TERMINATED BY '
'
(id, column2, column3, @date_time_variable) -- read one of the field to variable
SET date_time_column = STR_TO_DATE(@date_time_variable, '%d-%b-%Y'); -- format this date-time variable

它将像2011 年 1 月 31 日"这样的字符串格式化为正确的 DATETIME 数据类型.

It will format the string like '31-Jan-2011' to a correct DATETIME data type.

更多信息在这里 - LOAD DATA INFILE 语法.

More information here - LOAD DATA INFILE Syntax.

相关文章