Qt实时监控SQLite数据

Qt实时监控SQLite数据

  • 使用QFileSystemWatcher监视数据库,当数据有更新时触发信号,再重新读取所监视的值
// An highlighted block
#include <QCoreApplication>
#include <QDebug>
#include <QApplication>
#include <QDir>
#include <QSqlDatabase>
#include <QSqlQuery>



int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    QString databasePath = "D:/test6.db";
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName(databasePath);
    db.open();

    if(!db.open())
    {
        qDebug() << "Error: Failed to connect database.";
    }
    else
    {
        qDebug() << "Succeed to connect database.";
    }

    QSqlQuery query;
    query.exec("CREATE TABLE IF NOT EXISTS configuration (key TEXT PRIMARY KEY, value TEXT)");

    query.prepare("INSERT INTO configuration (key, value) VALUES (:key, :value)");
    query.bindValue(":key", "config_key");
    query.bindValue(":value", "config_value");

    query.exec("SELECT value FROM configuration WHERE key = 'color'");
    if (query.next()) {
        QString configValue = query.value("value").toString();
        qDebug() << configValue;
        // 在这里使用配置值
    }
    db.close();
    // 创建一个 QFileSystemWatcher 并添加数据库文件路径
    QFileSystemWatcher fileWatcher;
    fileWatcher.addPath(databasePath);

    // 监听 fileChanged 信号
    QObject::connect(&fileWatcher, &QFileSystemWatcher::fileChanged, [&](const QString& filePath) {
        if (filePath == databasePath) {
            qDebug() << "Database file changed:" << filePath;
            db.open();
            if(!db.open())
            {
                qDebug() << "Error: Failed to connect database.";
            }
            else
            {
                qDebug() << "Succeed to connect database.";
            }
            query.exec("SELECT value FROM configuration WHERE key = 'color'");
            if (query.next()) {
                QString configValue = query.value("value").toString();
                qDebug() << configValue;
                // 在这里使用配置值
            }
            db.close();
            // 在这里进行数据库操作或其他相应的逻辑
        }
    });



    return a.exec();
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用上述提供的代码来实现Qt实时监控并保存图片的功能。 首先,您需要创建一个包含视频监控功能的Qt窗口,通过`v4l2`和`opencv`库来获取视频流,并将视频流显示在窗口中。您可以使用`QTcpSocket`类来接收视频流数据,并在接收到数据后进行处理。通过解析JSON数据,您可以提取出图片数据,并保存为图片文件。您可以使用`QFile`类和`QImage`类来保存图片文件。 在代码中,`slot_TcpSocket_readyRead()`函数是用来接收数据的槽函数。当有数据传入时,该函数会被调用。在该函数中,您可以调用`analysis_Json()`函数来解析JSON数据,并根据需要处理图片数据。您可以使用`QByteArray`类和`QJsonDocument`类来解析JSON数据。 通过调用`on_pushButton_clicked()`函数,您可以开始监控并保存图片。在该函数中,您可以打开视频流,并将接收到的视频帧数据写入到图片文件中。您可以使用`QFileDialog`类来选择保存图片的路径。 总结起来,您可以按照以下步骤实现Qt实时监控并保存图片的功能: 1. 创建一个包含视频监控功能的Qt窗口,并通过`v4l2`和`opencv`库来获取视频流。 2. 使用`QTcpSocket`类来接收视频流数据,并在接收到数据后进行处理。 3. 解析接收到的JSON数据,提取出图片数据并保存为图片文件。 4. 在需要保存图片的时候,调用`on_pushButton_clicked()`函数来开始监控并保存图片。 5. 在该函数中,打开视频流并将接收到的视频帧数据写入到图片文件中。 请根据您的具体需求和代码实现,适配上述步骤。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [毕设新项目-基于C语言QT+v4l2+OpenCV+sqlite的视频监控系统源码+项目说明.zip](https://download.csdn.net/download/DeepLearning_/87753118)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [QT 短时间大量图片传输,实现监控效果 (实时视屏传输) (JSON 数据模式 )](https://blog.csdn.net/she666666/article/details/128292825)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [QT 短时间大量图片传输,实现监控效果 (实时视屏传输) (暴力模式)](https://blog.csdn.net/she666666/article/details/128282447)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值