mysql LOAD DATA INFILE 命令中是否有一个选项,将 .tsv
文件作为 mysql LOAD DATA INFILE 的输入,并将该文件中的每个“NA”字段转换为 mysql 中的 NULL ?
作为奖励,还能够采用多个不同的值,例如 'NaN'、'NA'、'--'
等,并将它们全部转换为 'NULL' .
最佳答案
您可以使用变量:
LOAD DATA LOCAL INFILE 'file.tsv' INTO TABLE my_table
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
(@col1, @col2, @col3)
SET
col1 = CASE WHEN @col1 NOT IN ('NA', 'NaN', '--') THEN @col1 END,
col2 = CASE WHEN @col2 NOT IN ('NA', 'NaN', '--') THEN @col2 END,
col3 = CASE WHEN @col3 NOT IN ('NA', 'NaN', '--') THEN @col3 END
像这样使用 CASE WHEN:
CASE WHEN @col1 NOT IN ('NA', 'NaN', '--') THEN @col1 END
当条件为真时,它将返回@col1 的实际值,否则返回 NULL
关于mysql LOAD DATA INFILE NA 到 NULL 转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33410876/