ハマログ

株式会社イーツー・インフォの社員ブログ

MySQLのSELECT結果をCSV出力

MySQLのSELECT結果をCSV出力するには以下のようにSELECT文に「INTO OUTFILE」を記述すればよいとのことです

SELECT * FROM users INTO OUTFILE 'example_users.csv';

試してみたところ以下の通りエラーとなってしまいました
ユーザにPROCESS権限がないとダメなようです

mysql -u user1 -p example_db
MySQL [example_db]> SELECT * FROM users INTO OUTFILE 'example_users.csv';
ERROR 1227 (42000): Access denied; you need (at least one of) the FILE privilege(s) for this operation

そこでベタな方法ですがSELECT結果(TSV出力)のタブ区切りをカンマ区切りに変換することで解決しました

echo 'SELECT * FROM `users`' | mysql -u user1 -p example_db | tr '\t' ',' > example_users.csv
CSVmysql

  yama   2024年1月25日


関連記事

AWS CDKでインフラ構築したので、CDKの概要や魅力を紹介

つい先月、私が関わっている案件でインフラリプレースをし、無事完了しました。そのと…

AWS Lambda/API GatewayのIP制限が解除されなくて困った話

AWSで環境構築・開発をするにあたって(AWSに限りませんがまあその)、 当然な…

Nagiosでpingの応答が返ってこないサーバを監視する

Nagiosで死活監視をしているサイトのうち、サービスステータスが正常なのにホス…


← 前の投稿

次の投稿 →