MySQLでCSVから列を指定してインポート
2024/01/12
MySQLでCSVからデータをインポートしたかった。またエクセル風にいうA列はidカラム、B列はnameカラムといったように列とカラムを紐付けてインポートしたい。以下に対応方法をメモ。
対応方法
load data local infile "/var/www/html/data.csv" into table test_table fields terminated by ',' optionally enclosed by '"'
(@1,@2,@3)
SET
id = @1,
name = @2,
age = @3
「/var/www/html/data.csv」はインポートしたいCSVファイルの保存場所を、test_tableはテーブル名に適宜書き換える。@1はA列、@2はB列といった形になる。
尚、日本語データが入らず半角英数字や日時は入るといった場合は文字コードを疑う。
参考サイト
https://www.virment.com/sql-for-import-csv-mysql/
所感
今までだとCSVデータをPHPで読み取り、PHPからMySQLに格納する方法を取っていたが今回の方法の方が楽そう。