Qt之内存数据库「终于解决」

数据库 (78) 2023-04-06 10:12

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说Qt之内存数据库「终于解决」,希望能够帮助你!!!。

  内存数据库,顾名思义就是将数据放在内存中直接操作的数据库。相对于磁盘,内存的数据读写速度要高出几个数量级,将数据保存在内存中相比从磁盘上访问能够极大地提高应用的性能。所以在有大量数据交互时使用内存数据库,等到数据交互量降下来以后同步至本地数据库也是个不错的选择。

  下段代码是我事先将部分数据插入内存数据库,便于后续数据交互时查表使用。

/*
* @brief 将自检信息表存入内存数据库中
* @return &MemoryQuery
*/
QSqlQuery* CreateMemoryDBAndStoreSCInfo()
{
    typedef struct 
    {
        int Type;      //类型
        int MainItem;  //主项
        int SubItem;   //子项
    }StSelfCheckInfo;
    /*
    *  在各枚举下不同索引对应的类型、主项、子项的值
    *  在查表时找到对应位置下的索引值即可知道是哪个子项
    */
    StSelfCheckInfo stSCInfoArr[32] = 
    {
        {0,0,0},{0,0,1},{0,0,2},{0,0,3},{0,0,4},   //4
        {0,2,0},{0,2,1},{0,2,2},{0,2,3},{0,2,4},   //9
        {0,0,5},{0,1,0},{1,4,0},{1,4,1},{1,0,0},   //14
        {1,0,1},{1,0,2},{1,0,3},{1,1,0},{1,1,1},   //19
        {1,1,1},{1,1,4},{1,1,3},{1,2,0},{1,3,0},   //24
        {1,6,0},{1,6,1},{1,7,0},{1,7,1},{1,5,0},   //29
        {2,0,0},{2,1,0}                            //31
    };
    QVariantList IdList,TypeList,MainItemList,SubItemList;
    for(int i = 0;i < 32;i++)
    {
        IdList << i;
        TypeList << stSCInfoArr[i].Type;
        MainItemList << stSCInfoArr[i].MainItem;
        SubItemList << stSCInfoArr[i].SubItem;
    }
    MemoryDb = QSqlDatabase::addDatabase("QSQLITE","Memory");
    MemoryDb.setDatabaseName(":memory:");/// 内存数据库,掉电会丢失
    if(!MemoryDb.open())
    {
        return NULL;
    }
    MemoryQuery = QSqlQuery::QSqlQuery(MemoryDb);
    /*
    *   自检枚举表
    */  
    QString StrMemoryQuery = "CREATE TABLE SCItemRetrievalTable(id INT8 NOT NULL primary key,Type INT8 NOT NULL,MainItem INT8 NOT NULL, SubItem INT8 NOT NULL)";
    MemoryQuery.exec(StrMemoryQuery);
    /*
    *   自检信息表
    */
    QString StrSCinfoQuery = "create table SCInfoTable (id INTEGER PRIMARY KEY, Datetime varchar(20),System varchar(10), TestType varchar(10), TestIndex varchar(20), TestResult varchar(20))";
    MemoryQuery.exec(StrSCinfoQuery);

    MemoryQuery.prepare("INSERT INTO SCItemRetrievalTable VALUES(?,?,?,?)");   
    MemoryQuery.addBindValue(IdList);
    MemoryQuery.addBindValue(TypeList);
    MemoryQuery.addBindValue(MainItemList);
    MemoryQuery.addBindValue(SubItemList);
    MemoryQuery.execBatch();    ///批量写入
    return &MemoryQuery;
}

在空闲时同步数据:

   /// 设定定时器开始同步内存数据库至本地数据库
   QTimer::singleShot(1000,this,SLOT(SyncSCInfoToLocalDb()));

不过现在同步的方法还有待改进...

​
// @brief 同步SCInfo表至本地事件处理函数
void SyncSCInfoToLocalDb()
{
    int Num = 0;
    typedef struct  
    {
        QString id;
        QString DateTime;
        QString System;
        QString TestType;
        QString TestIndex;
        QString TestResult;
    }StSCInfo;
    MemoryQuery = QSqlQuery::QSqlQuery(MemoryDb);
    MemoryQuery.exec("select count(*) from SCInfoTable");
    bool ret = MemoryQuery.next();
    if(ret)
    {
        Num = MemoryQuery.value(0).toInt();
        StSCInfo *stScInfoArr = new StSCInfo[Num];
        QString str = "";
        for(int i = 0;i < Num;i++)
        {
            str = QString("select DateTime,System,TestType,TestIndex,TestResult from SCInfoTable where id = %1").arg(i+1);
            MemoryQuery.exec(str);
            ret &= MemoryQuery.next();
            if(ret)
            {
                stScInfoArr[i].id = QString::number(i);
                stScInfoArr[i].DateTime = MemoryQuery.value(0).toString();
                stScInfoArr[i].System = MemoryQuery.value(1).toString();
                stScInfoArr[i].TestType = MemoryQuery.value(2).toString();
                stScInfoArr[i].TestIndex = MemoryQuery.value(3).toString();
                stScInfoArr[i].TestResult = MemoryQuery.value(4).toString();
            }
        }
        QString StrSyncQuery = "INSERT INTO TestTable SELECT '" + stScInfoArr[0].id  + "'AS 'id' ,'" + stScInfoArr[0].DateTime  + "'AS 'Datetime' ,'" + stScInfoArr[0].System + "'AS 'System', '" + stScInfoArr[0].TestType + "'AS 'TestType' ,'"+ stScInfoArr[0].TestIndex + "'AS 'TestIndex' ,'" + stScInfoArr[0].TestResult + "'AS 'TestResult'";
        QString StrSyncUnionQuery= "";
        for(int j = 1;j < Num;j++)
        {
            StrSyncUnionQuery = "UNION ALL SELECT '" + stScInfoArr[j].id + "' ,'"  + stScInfoArr[j].DateTime + "' ,'" + stScInfoArr[j].System + "' ,'" + stScInfoArr[j].TestType + "','"  + stScInfoArr[j].TestIndex + "' ,'"+ stScInfoArr[j].TestResult + "' ";
            StrSyncQuery = StrSyncQuery+ StrSyncUnionQuery;
        }
        QSqlQuery query;
        query.setForwardOnly(true);
        query.exec(StrSyncQuery);
        delete[] stScInfoArr;
        stScInfoArr = NULL;
    }
}

​

参考资料:

https://www.sqlite.org/inmemorydb.html

https://blog.csdn.net/qq_24127015/article/details/100510848

https://www.cnblogs.com/soqu36/p/9153855.html

发表回复