質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

2回答

563閲覧

MySQLのLOADでCSVインポートすると行末と次の行頭フィールド値が1つの行末フィールドに入ってしまう

fukazume

総合スコア78

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

0クリップ

投稿2020/08/24 02:45

##◆質問
以下、現象を解消し、行末のurlフィールドにurlだけを入れる方法を教えていただけますでしょうか。

##◆現象

LOAD文で以下のようなCSVソースをMySQLに空の任意テーブルにインポートすると、以下のように行末のフィールド内に行末と次の行頭フィールド値が入ってしまいます。

##◆気づいたおかしな点
フィールド内で改行されている、改行コード\n左右にあるダブルクォートが残っています。

MySQL

1LOAD DATA LOCAL INFILE "C:/Users/test/dev/info/data/osaka01.csv" 2INTO TABLE tbl_info 3FIELDS TERMINATED BY ',' 4OPTIONALLY ENCLOSED BY '\"' 5LINES TERMINATED BY '\n' 6IGNORE 1 LINES 7(@datetime, @pref, @city, @title, @url) 8SET datetime=@datetime, pref=@pref, city=@city, title=@title, url=@url 9

CSVソース

CSV

1"Wed, 15 Jul 2020 09:00:00 +0900","大阪府","大阪市","たこ焼きについて","https://www.takoyaki.jp/page/05055.html" 2"Wed, 08 Jul 2020 09:00:00 +0900",…

インポート後のurlフィールド値

MySQL

1mysql> select url from tbl_info; 2+-----------------------------------------------------------------------------------------------------+ 3| url | 4+-----------------------------------------------------------------------------------------------------+ 5| https://www.takoyaki.jp/page/050955.html" 6"Wed, 08 Jul 2020 09:00:00 +0900 |

どうぞよろしくお願い申し上げます。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/08/24 02:46

'\"' ここにエスケープシーケンスって必要でしたっけ
fukazume

2020/08/24 02:51

ご指摘ありがとうございます。エスケープなしでもインポート試みましたが同じインポート結果でした(泣) OPTIONALLY ENCLOSED BY '"'
guest

回答2

0

ベストアンサー

試しに最初の行だけで実行したらどうなりますか?
改行コードがLFとかCRLFという事も考えられますので、識別できるエディタ―(サクラエディタとか)で内容を確認してみて下さい。

投稿2020/08/24 04:13

sazi

総合スコア25206

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

fukazume

2020/08/24 04:27

原因はVSCODEの改行がCRLFだったことでした、LFに変更したらURLのみが行末フィールドに入りました!いままで検索置換窓で改行コード"\n"を入力したらヒットしていたので、この周辺は正しいのではと勘違いしておりました。ありがとうございました!
guest

0

なんともいえませんが、

  • 改行マークが実は「\n」ではないとか・・・
  • 「STARTING BY ''」をつけてみるとか・・・

投稿2020/08/24 02:53

yambejp

総合スコア115010

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問