RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1325256
Accepted
Konstantin
Konstantin
Asked:2022-09-04 20:00:47 +0000 UTC2022-09-04 20:00:47 +0000 UTC 2022-09-04 20:00:47 +0000 UTC

如何将 BLOB 文件插入数据库 QtSql.QSqlQuery()

  • 772

使用以下方法将数据插入数据库QtSql.QSqlQuery():

query = QSqlQuery()
query.prepare("INSERT INTO person (id, forename, surname) "
              "VALUES (:id, :forename, :surname)")
query.bindValue(":id", 1001)
query.bindValue(":forename", "Bart")
query.bindValue(":surname", "Simpson")
query.exec_()

问题:如果数据如何插入BLOB?

如果可能的话,一个小例子。我从逻辑上理解需要翻译成什么BLOB,然后插入一个变量......

最小的例子:

from PySide2 import QtSql
import os

def convertToBinaryData(file_path):
    # Конвертирование в BLOB
    with open(file_path, 'rb') as file:
        blobData = file.read()
        print()
    return blobData


def createConnection():
    db = QtSql.QSqlDatabase.addDatabase("QSQLITE")
    db.setDatabaseName("local_base.db")  # !!! .db
    if not db.open():
        print("Cannot establish a database connection")
        return False
    return db

# Получим данные BLOB
# картинка test_BLOB.jpg рядом с файлом скрипта
file_path = (f"{os.getcwd()}\\test_BLOB.jpg")
test_BLOB = convertToBinaryData(file_path)

db = createConnection()
db.transaction()
q = QtSql.QSqlQuery()
q.exec_("DROP TABLE IF EXISTS company;")
q.exec_("CREATE TABLE company ("
        "id INT PRIMARY KEY, "
        "name_company TEXT NOT NULL, "
        "blob_data BLOB NOT NULL );")

# Вставка тестовых значений

query = QtSql.QSqlQuery()
query.prepare("INSERT INTO company (id, name_company, blob_data) "
              "VALUES (:id, :name_company, :blob_data)")
query.bindValue(":id", 1)
query.bindValue(":name_company", 'АО КОПЫТА')
query.bindValue(":blob_data", test_BLOB)
query.exec_()

db.commit()


if __name__ == '__main__':
    print("Запуск")

idname_company它插入底座,但不插入BLOB。

python
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    S. Nick
    2022-09-04T20:25:49Z2022-09-04T20:25:49Z

    试试这样:

    import sys
    from PyQt5.QtWidgets import QMessageBox, QWidget, QApplication, \
        QVBoxLayout, QPushButton, QComboBox, QLabel, QFileDialog
    from PyQt5.QtCore import QDir, QFile, QFileInfo, QIODevice
    from PyQt5.QtGui import QPixmap
    from PyQt5.QtSql import QSqlDatabase, QSqlQuery, QSqlTableModel
    
    
    def createConnection():
        db = QSqlDatabase.addDatabase('QSQLITE')
        db.setDatabaseName("testImage_q1325256.db")
        
        if not db.open():
            QMessageBox.critical(None, "Не удается открыть базу данных ",
                    "Не удалось установить соединение с базой данных.\n"
                    "Этот пример требует поддержки SQLite. Пожалуйста, прочитайте Qt SQL "
                    "документацию для получения информации о том, как ее построить.\n\n"
                    "Click Cancel to exit.",
                    QMessageBox.Cancel)
            return False
    
        query = QSqlQuery()
        return query.exec_('''
            CREATE TABLE IF NOT EXISTS imgTable
                (
                 id INTEGER primary key AUTOINCREMENT, 
                 filename TEXT, 
                 imagedata BLOB
                )
        ''')
    
    
    class Demo(QWidget):
        def __init__(self):
            super().__init__()
    
            self.load_btn = QPushButton("Выбрать изображение и загрузить в БД")
            self.combo = QComboBox()
            self.label = QLabel()
            
            self.model = QSqlTableModel()
            self.model.setTable("imgTable")
            self.model.select() 
            
            self.combo.setModel(self.model)
            self.combo.setModelColumn(1)
            
            vbox = QVBoxLayout(self)
            vbox.addWidget(self.load_btn)
            vbox.addWidget(self.combo)
            vbox.addWidget(self.label)
    
            self.load_btn.clicked.connect(self.load_image)
            self.combo.currentIndexChanged.connect(self.on_change_select)
    
        def on_change_select(self, row):
            ix  = self.combo.model().index(row, 2)
            pix = QPixmap()
            pix.loadFromData(ix.data())
            self.label.setPixmap(pix)
    
        def load_image(self):
            fname, _ = QFileDialog.getOpenFileName(
                self, 
                'Open file', 
                QDir.currentPath(), 
                "Image files (*.jpg, *.gif, *.png)"
            )
            if fname:
                self.saveImage(fname)
    
        def saveImage(self, filename):
            file = QFile(filename)
            if not file.open(QIODevice.ReadOnly):
                return
    
            ba = file.readAll()
            name = QFileInfo(filename).fileName()
            
            record = self.model.record()
            record.setValue("filename", name)
            record.setValue("imagedata", ba)
    
            if self.model.insertRecord(-1, record):
                self.model.select()
    
    
    if __name__ == '__main__':
        app = QApplication(sys.argv)
        if not createConnection():
            sys.exit(-1)
        w = Demo()
        w.show()
        sys.exit(app.exec_())
    

    在此处输入图像描述

    在此处输入图像描述

    • 2
  2. Konstantin
    2022-09-04T21:04:18Z2022-09-04T21:04:18Z

    一般来说,我不知道这有多正确,但是在 convertToBinaryData 函数的结果之后,您需要另外通过 QtCore.QByteArray 传递 blobData 并将其插入到 INSERT INTO 中。然后一切都被显着插入,但这是一个纯粹直观的解决方案)

    from PySide2 import QtSql, QtCore
    import os
    
    def convertToBinaryData(file_path):
        # Конвертирование в BLOB
        with open(file_path, 'rb') as file:
            blobData = file.read()
            print()
        return blobData
    
    
    def createConnection():
        db = QtSql.QSqlDatabase.addDatabase("QSQLITE")
        db.setDatabaseName("local_base.db")  # !!! .db
        if not db.open():
            print("Cannot establish a database connection")
            return False
        return db
    
    # Получим данные BLOB
    # картинка test_BLOB.jpg рядом с файлом скрипта
    file_path = (f"{os.getcwd()}\\test_BLOB.jpg")
    test_BLOB = convertToBinaryData(file_path)
    ba = QtCore.QByteArray(test_BLOB)
    
    db = createConnection()
    db.transaction()
    q = QtSql.QSqlQuery()
    q.exec_("DROP TABLE IF EXISTS company;")
    q.exec_("CREATE TABLE company ("
            "id INT PRIMARY KEY, "
            "name_company TEXT NOT NULL, "
            "blob_data BLOB NOT NULL );")
    
    # Вставка тестовых значений
    
    query = QtSql.QSqlQuery()
    query.prepare("INSERT INTO company (id, name_company, blob_data) "
                  "VALUES (:id, :name_company, :blob_data)")
    query.bindValue(":id", 1)
    query.bindValue(":name_company", 'АО КОПЫТА')
    query.bindValue(":blob_data", ba)
    query.exec_()
    
    db.commit()
    
    
    if __name__ == '__main__':
        print("Запуск")
    
    • 0

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

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

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 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