- ベストアンサー
CSVからNULL値をインポート
phpMyAdminを使用してcsvからデータをインポートしようとしています。 通常の値は問題なくインポートできるのですが、NULL値があるフィールドがどうしても「0」になってしまいます。(そのフィールドはNULL値が入力可で、デフォルト値もNULLです) csvからNULL値をインポートする方法をご教授下さい。 宜しくお願いします。 ※\Nを入力するとNULLになるという情報があったため、 "1";"2";"3";"4";\N "1";"2";"3";"4";"\N" (1.2.3.4は適当な文字で、5番目をNULLにしたい) の両方を試みましたが、入力結果は「0」でした。 phpMyAdmin - 2.10.2 MySQL クライアントのバージョン: 5.0.18 フィールド区切り記号 ; フィールド囲み記号 ""
- みんなの回答 (2)
- 専門家の回答
質問者が選んだベストアンサー
"1";"2";"3";"4";NULL でいけませんか?
その他の回答 (1)
- hrm_mmm
- ベストアンサー率63% (292/459)
改行コード(MySQLはdefaultの行末コード\n)のせいで、末尾カラムに文字があると判断されて、カラムが数値型の場合は0に変換されてたりとか。 windowsでは特に、改行コード"\r\n"も指定が必要です。
お礼
ご回答ありがとうございました。 Myphpadminで「/r/n」だと、逆に正しく処理されませんでした。 「/n」に直すと、正常にインポートできました。 文字コードが「UTF8」だからでしょうか。。。。 とりあえず解決いたしましました。ありがとうございました。 「LOAD DATA LOCAL INFILE 'ファイル名' INTO TABLE `テーブル名` FIELDS TERMINATED BY ';' ENCLOSED BY '"' ESCAPED BY '\\' LINES TERMINATED BY '\n' 」
お礼
遅くなって、申し訳ありません。 教えていただいた通り、NULLで実行したのですが、結果が変わらなかったため、以下のコマンドを手で入力すれば、NULLがNULLとして認識されました。 「LOAD DATA LOCAL INFILE 'ファイル名' INTO TABLE `テーブル名` FIELDS TERMINATED BY ';' ENCLOSED BY '"' ESCAPED BY '\\' LINES TERMINATED BY '\n' 」 ありがとうございました。