首頁 >資料庫 >mysql教程 >如何成功地將包含多行文字欄位的 CSV 匯入 MySQL?

如何成功地將包含多行文字欄位的 CSV 匯入 MySQL?

Barbara Streisand
Barbara Streisand原創
2025-01-02 19:35:39467瀏覽

How Can I Successfully Import a CSV with Multi-Line Text Fields into MySQL?

將CSV 檔案匯入MySQL 表

將CSV 檔案載入到MySQL 表可能是一項簡單的任務,但有時會遇到複雜的情況,因為格式問題。當 CSV 檔案的某些欄位中包含多行文字時,就會出現這樣的問題。

在所呈現的場景中,使用者建立了一個 MySQL 表,其中為 CSV 檔案中的每個欄位包含對應的資料列,包括 VARCHAR( 256) 文字簡介欄位。但是,當嘗試使用 LOAD DATA INFILE 語句載入資料時,整個表都會被 NULL 值填入。

根本問題源自於 MySQL 將新行解析為行分隔符號的預設行為。為了解決此問題,使用者在LOAD DATA 語句中指定了其他參數,包括:

  • COLUMNS TERMINATED BY ',':列的分隔符號
  • 可選地用'"'括起來:文字分隔符fields
  • ESCAPED BY '"':文字欄位中引號的轉義字元
  • LINES TERMINATED BY 'n':行分隔符號
  • 忽略 1 LINES:跳過標題行

雖然此方法允許使用者載入正確數量的記錄,但某些資料仍保持錯誤的順序。為了解決這個問題,使用者探索了匯入 CSV 檔案的替代方法。

一種建議的方法涉及使用 mysqlimport 工具:

mysqlimport --ignore-lines=1 \
            --fields-terminated-by=, \
            --local -u root \
            -p Database \
             TableName.csv

該工具允許指定與 LOAD 類似的各種參數DATA 語句,包括行和字段分隔符。透過使用 mysqlimport,使用者可以確保資料以正確的格式和順序載入。

以上是如何成功地將包含多行文字欄位的 CSV 匯入 MySQL?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn