mysqldumpでは CSV出力 with headings ができなさそう

Elasticsearch に MySQL のとあるテーブルをまるっと取り込もうとしたときに、mysqldump コマンドで ヘッダーとデータ1行のCSVを出力できるかなと方法を探ったんですが見つからなかった
ちなみにまるっと取り込むのはLogstash経由にすればそのCSVなくてもできると判明

What I learned

🙅🏻‍♀️ mysqldump では CSV出力 with headings ができなさそう
🙆 以下のようなSQL + コマンドでならTSV出力できそう

echo “SELECT * FROM city LIMIT 1;” | mysql -uroot -psecret world > city1.tsv

Footprint

  • CSV出力(ヘッダーなし)するコマンド例

mysqldump -h localhost -P 3306 -u root -p — tab=/tmp — fields-terminated-by=, — skip-dump-date — complete-insert -t world city — where=”true limit 1" > city.csv

Appendix

a wanderer, aiming a good IT service `Practitioner`

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store