有效负载

时间:2016-07-06 10:00:08

标签: c++ mysql qt notifications psql

我目前正在处理将添加到表视图新行的applciation,它被插入到db的表中。我从基础类开始处理通知和设置触发器:

CREATE OR REPLACE FUNCTION notify_tableIWantToObserve_update()
  RETURNS trigger AS $$
DECLARE
BEGIN
    PERFORM pg_notify(
        CAST('tableIWantToObserve_update' AS text),
        (NEW.tableIWantToObserve_id)::text);
    return new;
END;
$$ LANGUAGE plpgsql;

CREATE TRIGGER tRIGGER_notify_tableIWantToObserve_update
  AFTER UPDATE
  ON tableIWantToObserve
  FOR EACH ROW
  EXECUTE PROCEDURE notify_tableIWantToObserve_update();

因此,它会在有效载荷中发送带有更新行ID的NOTfy。这就是我想要的 - 因为重新加载整个表只是以后不会做的。

我检查了QSqlDriver的文档 http://doc.qt.io/qt-5/qsqldriver.html#notification-1

有了它,我创建了我的“处理程序”:

//这是它的构造函数

MyDB =  new QSqlDatabase(QSqlDatabase::addDatabase("QPSQL", "Main"));

//Removed my data from here (just fro sake of this post)
MyDB->setHostName("-");
MyDB->setPort(0);
MyDB->setDatabaseName("-");
MyDB->setUserName("-");
MyDB->setPassword("-");

MyDB->open();


if( MyDB->isOpen() )
{
qDebug()<<"Connected to DB!";
QObject::connect(
        MyDB->driver(),
        SIGNAL(notification(const QString&, QSqlDriver::NotificationSource, const QVariant)),
        this,                   
        SLOT(slot_DBNotification_Recieved_NotifiAndPayload((const QString&, const QVariant)));
        );
}
else
qDebug()<<"NOT connected to DB!";

但它不会起作用。只有使用单个QString的驱动程序信号才会连接它 - 我需要的版本(附加信息)不会连接。

我将我的QT更新为5.7,但即使在QTCreater中,它只是向我显示驱动程序的信号只有单个字符串。

有没有解决方法?我真的需要使用该信号来检索更新的行ID。

编辑1:

我的处理程序的那个插槽:

void NotifiHandlerr::slot_DBNotification_Recieved_NotifiAndPayload(const QString& MSG, const QVariant &payload)
{
    qDebug() << "I WAS NOTIFIED ABOUT : " + MSG+" WITH DATA : "+payload.toString();
}

编辑2:

我尝试在我的插槽中添加QSqlDriver :: NotificationSource作为参数,但我不能 - 它仍然在.h中重复出错NotificationSource未声明。

编辑3:

我在这里添加了大部分代码(处理程序类)

// WHOLE .h
#include <QDebug>
#include <QObject>
#include <QString>
#include <QSqlDatabase>
#include <QSqlDriver>
#include <QVariant>
#include <QSqlDriverPlugin>
#include <qsqldriver.h>


class Handler : public QObject
{
    Q_OBJECT
public slots:
    void slot_DBNotification_Recieved_NotifiAndPayload
        (const QString& name, QSqlDriver::NotificationSource source, const QVariant& payload);

public:
    explicit Handler();
    ~Handler();

private:
    QSqlDatabase MyDB;
};






//WHOLE .cpp
#include "Handler.h"

Handler::Handler()
{
MyDB =  new QSqlDatabase(QSqlDatabase::addDatabase("QPSQL", "Main"));

    MyDB->setHostName("-");
    MyDB->setPort(0);
    MyDB->setDatabaseName("-");
    MyDB->setUserName("-");
    MyDB->setPassword("-");

    MyDB->open();


    if( MyDB->isOpen() )
    {
    qDebug()<<"Connected to DB!";
    MyDB->driver()->subscribeToNotification("tableIWantToObserve_update");
    QObject::connect(
        MyDB->driver(),
        SIGNAL(notification(const QString&, QSqlDriver::NotificationSource, const QVariant)),
        this,                   
        SLOT(slot_DBNotification_Recieved_NotifiAndPayload((const QString&, const QVariant)));
        );
    }
    else
    qDebug()<<"NOT connected to DB!";
}

Handler::~Handler()
{
       MyDB->driver()->unsubscribeFromNotification("tableIWantToObserve_update");
      MyDB->cloe();
}

void NotificationMaster::slot_DBNotification_Recieved_NotifiAndPayload
(const QString &name, QSqlDriver::NotificationSource source, const QVariant &payload)
{
    qDebug() << "I WAS NOTIFIED ABOUT : " + name+" WITH DATA : "+payload.toString();
}

只是为了消除这个想法 - 我添加了

QT += sql

在我的.pro文件中

2 个答案:

答案 0 :(得分:0)

您的广告位有错误的签名,以下是您应该如何定义的。

在您的标头文件中:

if (myScanner.IsScanSourceSupported(ImageScannerScanSource.AutoConfigured))
{
    ...
    // Scan API call to start scanning with Auto-Configured settings. 
    var result = await myScanner.ScanFilesToFolderAsync(
        ImageScannerScanSource.AutoConfigured, folder).AsTask(cancellationToken.Token, progress);
    ...
}

并且在构造函数中,当您连接插槽时,您应首先订阅通知:

//in order to be able to use the enum QSqlDriver::NotificationSource
#include <QSqlDriver>
...
...

class Handler : public QObject{
    Q_OBJECT
public:
    explicit Handler(QObject *parent = 0);
    ~Handler();
    ...
    ...
    ...
public slots:
    void SqlNotification(const QString& name, QSqlDriver::NotificationSource source,
                         const QVariant& payload);
    ...
    ...
};

您可能需要在析构函数中取消订阅(因为您不想再收到通知):

QSqlDatabase::database().driver()->subscribeToNotification("notification_name");
connect(QSqlDatabase::database().driver(),
        SIGNAL(notification(QString,QSqlDriver::NotificationSource,QVariant)), this,
        SLOT(SqlNotification(QString,QSqlDriver::NotificationSource,QVariant)));

和你的插槽实现:

QSqlDatabase::database().driver()->unsubscribeFromNotification("notification_name");

答案 1 :(得分:0)

我和anserw发布的代码或多或少都是正确的,但需要做的是在较新版本的qt creator中重新创建whoel项目,以便解决缺少函数和名称空间本身的问题。只需创建新项目并将所有文件粘贴到那里。