7

HeidiSQLを使用してcsvファイルをMySQLデータベースにインポートしたいと思います。

しかし、私のフィールドのいくつかは空です。

これらの空の値をNULL値と見なす必要があることをHeidiSQLに知らせるにはどうすればよいですか?

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
4

2 に答える 2

7

NULLを書き込む代わりに、空の各フィールドに\ Nを書き込むことで解決した場合!

于 2012-09-07T14:29:04.673 に答える
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)

(行末マーカーなどによっては、これを調整する必要がある場合がありますが、これは必要なものにかなり近いはずです)

于 2012-09-07T14:19:50.207 に答える