質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

2回答

439閲覧

C# コンボボックスにホスト名を入力し接続する方法

退会済みユーザー

退会済みユーザー

総合スコア0

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

0クリップ

投稿2017/07/13 00:51

C#を使用してWindowsフォームのアプリケーションを作成しています。
コンボボックスにホストを入力し、ボタンを押すことでリストボックスに指定したホストのMySQLに接続するといったものです。
ですがなかなかうまくいきません。

C#

1 private void button1_Click(object sender, EventArgs e) 2 { 3 string tmpCon = "server={0};uid={1};pwd={2}"; 4 con = new MySqlConnection(); 5 con.ConnectionString = 6 String.Format(tmpCon, 7 comboBox1.Text, "userID", "password"); 8 com = new MySqlCommand(); 9 com.Connection = con; 10 11 com.CommandText = "SHOW DATABASES;"; 12 con.Open(); 13 dtr = com.ExecuteReader(); 14 15 listBox1.Items.Clear(); 16 17 while (dtr.Read()) 18 { 19 listBox1.Items.Add(dtr[0]); 20 } 21 dtr.Close(); 22 con.Close(); 23 }

localhostには繋がるのですが、ほかのホストを指定しても、
Unable to connect to any of the specified MySQL hosts
というエラーが表示されてしまいます。
うまくいかなかったときは自分でMessageBoxを表示させたいのですが、どのようにしたらいいのでしょうか?

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

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

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

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

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

guest

回答2

0

接続できない件

localhost以外のホストには本当に繋がるのでしょうか。
一度別のMySQLに接続できるツールを使用してlocalhost以外のホスト(comboBox1に列挙されているホスト名)に接続できるか確認してみてください

エラーメッセージを出す方法

button1_Clickの処理を try ~ catchで括れば良いと思います

Google検索 C# try

csharp

1private void button1_Click(object sender, EventArgs e) 2{ 3 try 4 { 5 string tmpCon = "server={0};uid={1};pwd={2}"; 6 con = new MySqlConnection(); 7 con.ConnectionString = 8 String.Format(tmpCon, 9 comboBox1.Text, "userID", "password"); 10 com = new MySqlCommand(); 11 com.Connection = con; 12 13 com.CommandText = "SHOW DATABASES;"; 14 con.Open(); 15 dtr = com.ExecuteReader(); 16 17 listBox1.Items.Clear(); 18 19 while (dtr.Read()) 20 { 21 listBox1.Items.Add(dtr[0]); 22 } 23 dtr.Close(); 24 con.Close(); 25 } 26 catch(Exception e) 27 { 28 //エラー時にここに来る 29 MessageBox.Show(e.Message); 30 } 31}

投稿2017/07/13 02:55

MMashiro

総合スコア2378

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

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

退会済みユーザー

退会済みユーザー

2017/07/18 01:06

しっかりと他ホストには繋がるようになっています。 comboBoxにはlocalhostのみ入っており、あとはIPアドレスを指定しての接続となります。
MMashiro

2017/07/18 01:27

提示されているコードを使用して、MySQLではないですがSQLServerを使用して似たような処理を書いたところlocalhostや外部ホスト問わず接続に成功しデータベース一覧を取得することが出来ました。 同じパソコンでphpMyAdmin等使用して外部ホストに繋がるのであればちょっと原因がわかりません
guest

0

代理検索:Unable to connect to any of the specified MySQL hosts
https://www.google.co.jp/search?hl=ja&q=Unable+to+connect+to+any+of+the+specified+MySQL+hosts&lr=lang_ja&gws_rd=ssl

どこで、エラーが発生しているか位は、解りますよね?
回答者は、貴方の隣で同じ画面を見ているわけではありません。
エラー発生個所を明示してください。

投稿2017/07/13 01:35

daive

総合スコア2028

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問