databasethread.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. #ifndef DATABASETHREAD_H
  2. #define DATABASETHREAD_H
  3. #include <QThread>
  4. #include <QDateTime>
  5. #include <QSqlDatabase>
  6. #include <QSqlQuery>
  7. #include <QSqlError>
  8. #include <QVariant>
  9. #include <QStringList>
  10. #include <QList>
  11. #include "AlarmReport.h"
  12. class ApTable {
  13. public:
  14. ApTable(QString deviceid,QString sql,QString time,QString status,QString port,QString ncmd,QString pname,QString data1,QString content){
  15. DeviceId = deviceid;
  16. Sql = sql;
  17. Time = time;
  18. Status = status;
  19. Port = port;
  20. nCmd = ncmd;
  21. pName = pname;
  22. Data1 = data1;
  23. Content = content;
  24. }
  25. QString DeviceId;
  26. QString Sql;
  27. QString Time;
  28. QString Status;
  29. QString Port;
  30. QString nCmd;
  31. QString pName;
  32. QString Data1;
  33. QString Content;
  34. };
  35. class DatabaseThread : public QThread
  36. {
  37. Q_OBJECT
  38. public:
  39. explicit DatabaseThread(QObject *parent = nullptr);
  40. void appendSql(QString sql);
  41. void appendAlarm(AlarmRep rep);
  42. void appendTable(ApTable tab);
  43. void run();
  44. void check_devicelist();
  45. void stop();
  46. signals:
  47. void AlarmReport(QString addr, quint64 insertid, QString type, QString time, QString ptype, QString pnumber);
  48. void TableReport(QString deviceid,quint64 insertid,QString time,QString status,QString port,QString ncmd,QString pname,QString data1,QString content);
  49. void SqlLog(QString log);
  50. void MqttInfo(QString ip,QString port,QString name,QString passwd);
  51. public slots:
  52. private:
  53. int hour;
  54. QSqlDatabase db;
  55. QStringList sqlList;
  56. QList<AlarmRep> alarmRepList;
  57. QList<ApTable> apTableList;
  58. bool keep;
  59. };
  60. #endif // DATABASETHREAD_H