質問するログイン新規登録
CSV

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

MySQL

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

Q&A

解決済

4回答

3772閲覧

SQLサーバにあるCSVファイルをローカルに落としたい

unkle

総合スコア12

CSV

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

MySQL

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

0グッド

0クリップ

投稿2016/09/26 09:19

0

0

mysqlサーバにて、select結果を出力したCSVファイルがあります。
それを自分のローカルに落としたいのですが、どうすればよいのでしょうか。
目的としては、出力結果をExcelに用いて資料を作りたいだけです。

versionは5.6.19です。

初心者の質問だとは思いますが、宜しくお願いします。

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

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

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

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

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

tanat

2016/09/26 10:57

「mysqlサーバにて、select結果を出力したCSVファイルがあります。 」 とのことですが、これはどのようにして出力されましたか? 例えば、SSHで接続してmysqldumpで出力したとかでしょうか。
guest

回答4

0

普通に考えるとファイル転送を行うためにはFTPサーバが起動していないといけないため
MYSQLサーバにFTPサーバ入れて起動させてローカル側からCSVファイルをFTPコマンド
にてgetすることになります。

それができないような環境であればselect文自体をローカルで実行して一旦、テキスト
出力しておきローカルでCSVファイルを作成しなおした方が早いのではないかという
気がいたします。

接続先がリモートのMYSQLサーバであっても
コマンドプロンプト上で実行されたselect文は実行結果自体をコピー&ペーストして
しまえば簡単にローカルに落とせるわけですから、余程容量が大きくない限りは
このやり方も可能だと思います。

ご参考まで

投稿2016/09/26 22:26

Yatsurugi

総合スコア1630

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

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

Yatsurugi

2016/09/29 03:44

FTPコマンドでgetするところはFFFtpClientのようなFTPクライアントソフトで ファイル取得しても勿論構いません。あたり前のことですが、追記しておきます。
guest

0

自己解決

ご回答ありがとうございました。
皆様の助言もあり、無事解決できました。

投稿2016/10/13 11:42

unkle

総合スコア12

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

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

0

MySQLが動いているサーバがどういったサーバなのかがわからないところがありますが、一般的にファイルの転送をするのであれば、他の回答者さんの回答にある通り、FTPを使います。FTPは使えないけどSSHは使えるという場合は、s.t.さんの回答にあるようにSCPを使うという手もあります。質問文に

出力結果をExcelに用いて資料を作りたいだけです。

とあるところを見ると、質問者さんはWindowsを使ってらっしゃるんですかね(Macの可能性もありますが…)?Windowsでしたら、WinSCPというソフトがFTP、SCPの両方で使えますので、一度試してみてはいかがでしょうか。
もし、SSHが使えず、TELNETでしか繋げられないとなりましたら、これは力技になりますが、ファイル表示のコマンド(Unix/Linuxでいうところのcatコマンド)を実行させて、ターミナルソフト(TeraTermなど)のロギング機能で保存するというやり方もあります。ただ、ファイルの数と一ファイル辺りの容量によっては現実的な方法ではないです。
もしくは、クライアントとサーバの立場を逆転させて、質問者さんの環境にFTPサーバを立てて、MySQLが動いているサーバ側からFTP接続してファイルを転送するという手もあります(MySQLが動いているサーバ側にFTPクライアントがあればですが)。

TELNETすらも使えない(ターミナルソフトで繋げられない)、Webアプリでしか操作できないとなると、そのWebアプリ次第になりますかね。

投稿2016/09/29 14:54

archiver

総合スコア1575

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

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

0

サーバにFTP接続できるのであれば、FTPソフトでCSVがあるディレクトリからダウンロードするだけです。

SSH接続はできるがFTP接続ができない場合はFTP接続ができるサーバーまでSCPコマンド等でCSVファイルを引っ張ってFTPでダウンロードする。

レンタルサーバーでよくあるmysqlしか利用できないサーバーの場合、サービスにもよりますがコントロールパネルなどそのサービスのGUIで入手できるかもしれません。

投稿2016/09/26 09:43

s.t.

総合スコア2021

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問