RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1439317
Accepted
Konstantin
Konstantin
Asked:2022-08-15 01:40:53 +0000 UTC2022-08-15 01:40:53 +0000 UTC 2022-08-15 01:40:53 +0000 UTC

PySide2 和 MySQL 无法从数据库连接到显示表

  • 772

无法使用 QSqlTableModel 显示来自远程 QTableView 数据库的表(据我了解,与数据库本身的连接不起作用)。有一个代码不起作用,我无法弄清楚问题是什么......

import sys

from PySide2.QtCore import QSize
from PySide2.QtSql import QSqlDatabase, QSqlTableModel
from PySide2.QtWidgets import QApplication, QMainWindow, QTableView

db = QSqlDatabase.addDatabase("QMYSQL")
db.setHostName("server167.hosting.reg.ru")
db.setDatabaseName("db")
db.setUserName("<user name>")
db.setPassword("<password>")
db.open()

print(db, type(db))
if db.open():
    print("Database Open!")
else:
    print("Database NOT Open!")




class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()

        self.table = QTableView()

        self.model = QSqlTableModel(db=db)

        self.table.setModel(self.model)

        self.model.setTable("objects")
        self.model.select()

        self.setMinimumSize(QSize(1024, 600))
        self.setCentralWidget(self.table)


app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec_()

我检查了100次连接数据,由于填充表的代码是100%执行的,我当然可以把连接器全部拿走,但我真的很想用Qt =)填充数据库表的代码:

import mysql.connector as mysql

mysql_conn = mysql.connect(
    host='server167.hosting.reg.ru',
    user='u1082920_root',
    password='1501kZn1501!',
    database = 'u1082920_docs_db'
)

with mysql_conn as connection:
    cursor = connection.cursor()
    cursor.execute("""DROP TABLE IF EXISTS objects""")
    cursor.execute("""CREATE TABLE objects(id INTEGER PRIMARY KEY, data TEXT NOT NULL,
                                            plan TEXT NOT NULL, name_plan TEXT NOT NULL)""")
    # # SQL запрос на вставку
    query = f"INSERT INTO objects (id, data,plan,name_plan) VALUES ('{1}', '{str(2)}', '{str(3)}', '{str(4)}')"
    cursor.execute(query)
    query = f"INSERT INTO objects (id, data,plan,name_plan) VALUES ('{2}', '{str(2)}', '{str(3)}', '{str(4)}')"
    cursor.execute(query)

    connection.commit()
    connection.close()
mysql pyqt5
  • 2 2 个回答
  • 33 Views

2 个回答

  • Voted
  1. Best Answer
    Sergey Tatarincev
    2022-08-15T17:21:22Z2022-08-15T17:21:22Z

    为什么两次db.open()?

    检查数据库连接

    from PySide2.QtSql import QSqlError
    if db.open():
        print("Database Open!")
    else:
        print(f"Database NOT Open cause {db.lastError().text()}")
    

    我强烈怀疑会有错误QSqlDatabase: QMYSQL driver not loaded。见https://stackoverflow.com/questions/64056483/unable-to-load-qmysql-driver-on-pyside2

    • 1
  2. Konstantin
    2022-08-15T19:59:46Z2022-08-15T19:59:46Z

    正是因为没有 QMYSQL 驱动程序(感谢 Sergey Tatarincev)。我找到了最适合自己的方式来安装现成的驱动程序(即使我没有足够的说明,我也没有足够的知识来组装它们)。

    感谢好心人上传现成的驱动(例如QMYSQL驱动5.15.2)

    使用简单的安装说明(我将在此处给出,因为我认为它在存储库中不是很明显):

    部署

    1. 将qsqlmysql.dll(如果是release build)/qsqlmysqld.dll(如果是debug build,但注意当使用MinGW 8.1.0或更高版本时,debug build也称为qsqlmysql.dll)在应用程序的“sqldrivers”子目录中
    2. 将 libmysql.dll(MySQL 库本身)和 OpenSSL v1.1 库 libcrypto-1_1 和 libssl-1_1 放入您的应用程序目录

    原则上,在这些一切工作之后=)

    • 0

相关问题

  • MySQL - 将一列中单元格的每个值与另一列中的值匹配,并将其替换为相邻列中的值

  • 帮助编写 MySQL 查询

  • SELECT 只增加 MYSQL 值

  • 创建 MySQL 表时的字段

  • 如何连接到远程mysql数据库?

  • MySQL单元格中的随机值

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5