HeidiSQL导入csv空字段

时间:2012-09-07 13:25:14

标签: mysql csv null heidisql

我想用HeidiSQL将csv文件导入我的MySQL数据库。

但是我的一些字段是空的。

如何让HeidiSQL知道这些空值必须被视为NULL值?

csv文件样本(最后2个字段尚未知晓):

    NULL;Students Corner;437452182;;

创建命令:

    CREATE  TABLE `db`.`customers` (
         `company_id` INT NOT NULL AUTO_INCREMENT ,
         `company_name` VARCHAR(40) NULL ,
         `company_number` INT NULL ,
         `company_vat` INT NULL ,
         `company_zip` INT NULL,
    PRIMARY KEY (`company_id`) );

我收到这些错误:

    Incorrect integer value: '' for column 'company_id' at row 1 */
    Incorrect integer value: '' for column 'company_vat' at row 1 */
    Incorrect integer value: '' for column 'company_zip' at row 1 */
    etc

2 个答案:

答案 0 :(得分:7)

如果通过在每个空字段中写入\ N而不是写入NULL来解决它!

答案 1 :(得分:5)

您可以使用LOAD DATA INFILE查询将CSV文件导入MySQL。

在你的情况下,你会写这样的东西:

LOAD DATA INFILE filename.txt
INTO TABLE customers
FIELDS TERMINATED BY ';'
LINES TERMINATED BY '\n'
(@id, @name, @number, @vat, @zip)
SET
  company_id     = (CASE WHEN @id='' THEN NULL ELSE @id END),
  company_name   = (CASE WHEN @name='' THEN NULL ELSE @name END),
  company_number = (CASE WHEN @number='' THEN NULL ELSE @number END),
  company_vat    = (CASE WHEN @vat='' THEN NULL ELSE @vat END),
  company_zip    = (CASE WHEN @zip='' THEN NULL ELSE @zip END)

(您可能需要根据行标记的末尾等进行调整,但这应该非常接近您的需要)