🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
C#

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

MySQL

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

Q&A

解決済

1回答

1640閲覧

MYSQL IPアドレスを指定しているのにローカルホストに接続される

Qoo

総合スコア1249

C#

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

MySQL

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

0グッド

0クリップ

投稿2019/10/14 07:02

編集2019/10/17 07:08

下記のようにIP指定でMYSQLサーバに接続しているのですが、
接続先が指定したサーバのアドレスではなく、localhostであることがわかりました。

接続先を
SERVER = "localhost"; ←ローカルホストに接続される(開発環境)
SERVER = "133.XXX.XXX.XXX"; ←エラーもなく、SQLでデータも取得できるのでサーバに接続しているものだと思っていたらなぜか、ローカルホストからデータを取得していました。

接続先に接続できなかったら自動的にローカルを参照するようなことはないですよね?
何かおかしなところはありますでしょうか。

c#

1using System.Collections; 2using System.Collections.Generic; 3using UnityEngine; 4using UnityEngine.UI; 5using System; 6using MySql.Data; 7using MySql.Data.MySqlClient; 8 9public class FormControl : MonoBehaviour 10{ 11 12 public string SERVER = "133.XXX.XXX.XXX"; 13 public string DATABASE = "db"; 14 public string USERID = "root"; 15 public string PORT = "3306"; 16 public string PASSWORD = "xxx"; 17 18 public MySqlConnection conn; 19 20 void Start() 21 { 22 23 string connCmd = 24 "server=" + SERVER + ";" + 25 "database=" + DATABASE + ";" + 26 "userid=" + USERID + ";" + 27 "port=" + PORT + ";" + 28 "password=" + PASSWORD; 29 30 conn = new MySqlConnection(connCmd); 31 32 try 33 { 34 Debug.Log("MySQLと接続..."); 35 conn.Open(); 36 } 37 catch (Exception ex) 38 { 39 Debug.Log(ex.ToString()); 40 } 41 42 43 44 } 45 46 //アプリケーションの終了時 47 void OnApplicationQuit() 48 { 49 conn.Close(); 50 Debug.Log("接続を終了しました"); 51 } 52}

---補足---
サーバ上で下記のように外部からアクセスできるユーザを作成しています。
grant all privileges on . to test_user1@"%" identified by 'test1234' with grant option;

クライアント側の端末でmysqlを起動し、
mysql -h xxx.xxx.xxx.xxx -u test_user1 -p
で接続すると問題なく接続できました。

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

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

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

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

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

hihijiji

2019/10/14 09:14

> 接続先が指定したサーバのアドレスではなく、localhostであることがわかりました。 どうやって確認しましたか?
Qoo

2019/10/17 02:56

SQLでデータを取得した結果で確認しています。 web上のサーバとローカルサーバでレコードの数と値をそれぞれ、別のものにして どちらのデータが取得したかを見ております。 SQLの取得自体はできているので、SQL取得部分のコード掲載はしておりません。
hihijiji

2019/10/17 03:38

提示されている部分に問題はないので、提示してない部分を疑うしかないですね。 試しに、ネットワークから切断した状態で実行してみてください。
guest

回答1

0

ベストアンサー

"host=" + SERVER + ";" + にしても同じでしょうか?

投稿2019/10/14 08:42

salud

総合スコア215

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

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

Qoo

2019/10/17 02:53

"host=" + SERVER + ";" + にしてみましたが、同じようにローカルサーバに接続されてしまいます。。
Qoo

2019/10/17 08:52

string connCmd = "host=" + SERVER + ";" + "database=" + DATABASE + ";" + "userid=" + USERID + ";" + "port=" + PORT + ";" + "password=" + PASSWORD; の部分を string connCmd = @"Server=xxx.xxx.xxx.xxx;Database=db_test;Uid=test_user1;Pwd=test1234;"; にすることで無事接続できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問