it-swarm-ja.com

バッチを使用してcsvファイルをmysqlにロードしますか?

バッチを使用して.csvファイルをMySQLサーバーにロードするためのヘルプを探していますが、基本的な質問はほとんどありません。

問題:

1)CSVファイルデータの間に(カンマ)が含まれている可能性があります(例:説明)。これらのデータをインポート処理するにはどうすればよいですか?

2)ExcelからCSVをロードするには、コンマを含むデータを「」(二重引用符)で囲みます[以下の例のように]。インポートでこれをどのように処理できますか?

ヘッダー付きのサンプルCSVは次のとおりです:

name,id,Subject,ExamDate,Mark,Description
Prabhat,1,Math,2/10/2013,25,Test data for prabhat.
Murari,2,Science,2/11/2013,24,"Test data for his's test, where we can test 2nd ROW, Test."
sanjay,3,Science,,25,Test Only.

インポートに使用されるSQLステートメント:

load data local infile "c:\\eqa\\project\\input.csv" into table request character set latin1 fields terminated by',' lines terminated by'\n' ignore 1 lines

どうすればこれを行うことができますか?

1
seepana avinash

MySQLを使用してload data local infileおよび テーブルへのデータのロード を使用しているため、この問題の解決に役立つこの機能の一部として提供される簡単なソリューションがあります。

使用しているMySQL構文のFIELD句の一部としてENCLOSED BY '"'句を必ず含める必要があります。以下は、この例です。

load data local infile "c:\\eqa\\project\\input.csv" 
into table request 
character set latin1 
fields terminated by','
ENCLOSED BY '"'
lines terminated by'\n' 
ignore 1 lines

これにより、入力ファイルのフィールド値が二重引用符でコンマで区切られていることがわかります。 -二重引用符で囲まれたすべての文字がインポートされます。


その他のリソース

  • データをテーブルにロードする
  • LOAD DATA INFILE構文
    • LOAD DATA INFILEは、外部ソースから取得したファイルを読み取るために使用できます。たとえば、多くのプログラムでは、データをコンマ区切り値(CSV)形式でエクスポートできます。たとえば、行のフィールドはコンマで区切られ、二重引用符で囲まれ、列名の最初の行が含まれます。このようなファイルの行がキャリッジリターン/改行のペアで終了している場合、ここに示すステートメントは、ファイルのロードに使用するフィールド処理オプションと行処理オプションを示しています。

      LOAD DATA INFILE 'data.txt' INTO TABLE tbl_name
        FIELDS TERMINATED BY ',' ENCLOSED BY '"'
        LINES TERMINATED BY '\r\n'
        IGNORE 1 LINES;
      

      入力の場合、ENCLOSED BY文字が存在する場合は、フィールド値の末尾から削除されます。 (これは、OPTIONALLYが指定されているかどうかに関係なく当てはまります。OPTIONALLYは入力の解釈に影響しません。)ENCLOSED BY文字の前にあるESCAPED BY文字の出現は解釈されます。現在のフィールド値の一部として。

      フィールドがENCLOSED BY文字で始まる場合、その文字のインスタンスは、フィールドまたは行TERMINATED BYシーケンスが後に続く場合にのみフィールド値を終了するものとして認識されます。あいまいさを回避するために、フィールド値内でのENCLOSED BY文字の出現を2倍にして、文字の単一インスタンスとして解釈することができます。たとえば、ENCLOSED BY '"'が指定されている場合、引用符は次のように処理されます。

      "The ""BIG"" boss"  -> The "BIG" boss
      The "BIG" boss      -> The "BIG" boss
      The ""BIG"" boss    -> The ""BIG"" boss
      

      ソース

2
Pimp Juice IT