Python:QSqlDatabase:未加载QMYSQL驱动程序

时间:2013-04-10 20:36:37

标签: python mysql pyqt pyside

我从http://www.python.org/getit/运行python 2.7.3(python-2.7.3.amd64.msi)

我正在使用这些安装程序:http://www.lfd.uci.edu/~gohlke/pythonlibs/

  • 的PyQt-Py2.7-x64的GPL-4.9.6-1.exe
  • PySide-1.1.2.win-AMD64的py2.7.exe
  • 的MySQL-蟒-1.2.4.win-AMD64的py2.7.exe

我还尝试了来自:

的pyqt和pyside二进制文件

我在以下python代码中收到错误“QSqlDatabase:QMYSQL驱动程序未加载”。我最好的猜测是上面的pyside和pyqt二进制安装程序没有构建qt来包含QMYSQL?任何人都可以确认,更重要的是,将我引导到一个安装了QMYSQL驱动程序的安装程序?我不准备尝试自己编译qt库。任何帮助表示赞赏。

import sys

from showrec import *    # import qtdesigner ui (converted using pyside-uic)

from PySide import QtGui, QtSql

#===================================================================
# 
#===================================================================

def createConnection():

    db = QtSql.QSqlDatabase.addDatabase('QMYSQL')

    db.setHostName('localhost')
    db.setDatabaseName('mydatabase')
    db.setUserName('userid')
    db.setPassword('password')
    db.open()
    print (db.lastError().text())
    return True

#===================================================================
#
#===================================================================

class MyForm(QtGui.QDialog):

    def __init__(self, parent=None):

        #super(MyForm, self).__init__(parent)   # I suspect this is needed?

        QtGui.QWidget.__init__(self,parent)
        self.ui = Ui_Dialog()
        self.ui.setupUi(self)

        self.model = QtSql.QSqlDatabase(self)
        self.model.setTable("products")
        self.model.setEditStrategy(QtSql.QSqlTableModel.OnManualSubmit)
        self.model.select()
        self.ui.tableView.setModel(self.model)

#===================================================================
# main
#===================================================================

if __name__ == "__main__":

    app = QtGui.QApplication(sys.argv)

    if not createConnection():
        sys.exit(1)

    myapp = MyForm()
    myapp.show()

    sys.exit(app.exec_()) 

这是gui代码:

from PySide import QtCore, QtGui

class Ui_Dialog(object):
    def setupUi(self, Dialog):
        Dialog.setObjectName("Dialog")
        Dialog.resize(400, 300)
        self.tableView = QtGui.QTableView(Dialog)
        self.tableView.setGeometry(QtCore.QRect(20, 20, 256, 192))
        self.tableView.setObjectName("tableView")

        self.retranslateUi(Dialog)
        QtCore.QMetaObject.connectSlotsByName(Dialog)

    def retranslateUi(self, Dialog):
        Dialog.setWindowTitle(QtGui.QApplication.translate("Dialog", "Dialog", None, QtGui.QApplication.UnicodeUTF8))

2 个答案:

答案 0 :(得分:1)

关于PySide,官方64位Windows安装程序(从PySide主页下载)仅支持QSQLITE驱动程序。 32位安装程序支持QSQLITE QODBC3 QODBC QPSQL7 QPSQL驱动程序。 R上。

答案 1 :(得分:0)

我决定使用pyqt4而不是pyside,因为安装程序包含QMYSQL驱动程序。