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

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

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

QtはGUIプログラムの開発で広く使われているクロスプラットフォーム開発のフレームワークです。

Q&A

解決済

1回答

2287閲覧

PyQT DB接続について

wasi300

総合スコア66

Qt

QtはGUIプログラムの開発で広く使われているクロスプラットフォーム開発のフレームワークです。

0グッド

0クリップ

投稿2015/06/26 07:41

PyQT4.11.4のpython2.7向けのWindows版を使ってます。
外部WebサーバーのMySQLの制御がしたいのですが、10061のエラーが出て接続ができなくて困っています。
そこで質問させてください。

1.PyQTから直接外部のDBを操作するにはqsqlmysql4.dllをsqldriversに入れてPyQT内のlibmysql.dllにパスを通す以外に何か準備が必要でしょうか?

2.PyQTで作成したアプリでそもそも直接外部MySQLを操作するのは一般的でしょうか?MySQLだけは別のプログラムで制御したりするのでしょうか。

接続用のコードはこのように書きました。

lang

1 db = QSqlDatabase.addDatabase('QMYSQL') 2 db.setHostName("210.*.*.*") 3 db.setPort(3306); 4 db.setDatabaseName("dbname") 5 db.setUserName("id") 6 db.setPassword("pw") 7 8 if (db.open()==False): 9 QMessageBox.critical(None, "Database Error", 10 db.lastError().text())

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

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

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

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

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

guest

回答1

0

ベストアンサー

PyQTの使用経験はありませんが、まずはどちら側に問題があるのか切り分けたらいかがでしょうか。
例えばWindowsのDOSプロンプトで

c:\Users\user>telnet 210...* 3306

※telnet は Ctrl+[ で切断できます。

で変な文字が表示されれば3306ポートでMySQLが動作状態であることが確認できます。
時間がかかって「接続に失敗しました」というメッセージですとMySQLまで到達できて
いないと考えられます。

MySQL側に問題がある場合は
そもそもMySQLが起動しているのか、ポート3306が開いているか(ファイアーウォールなど)、
起動時に--skip-networking指定、またはmy.cnfにskip-networkingの指定が無いか
などチェックされてはいかがでしょうか。

投稿2015/06/26 11:21

packet1024

総合スコア342

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

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

wasi300

2015/06/26 16:53 編集

nodename nor servname provided, or not knownって出ました。まだ確認できるところが結構ありそうなので、色々見直してみます・・・。ありがとうございます。
wasi300

2015/07/02 05:16

ホストを許可していなかったというか、ホスト名が変わっててMySQLにたどりつけていませんでした・・・。mysqlのuserテーブルにユーザーとホストを追加することで、とりあえず辿り着けるようになりました。 http://yakumo80.blog33.fc2.com/blog-entry-36.html packet様のアドバイス以外に上記のサイトも参考になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問