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に格納する方法を取っていたが今回の方法の方が楽そう。