【Qt】在表格QTableWidget或者QTableView中,当主键Id存在时更新数据,不存在时添加数据解决方案

问题

有时在开发中,表格需要显示数据,每一行呢,需要记录对应的id。

当更新表格数据时,会根据id进行更新,id存在就更新行数据,不存在就添加一行新数据。

解决方案

如何知道id存在还是不存在呢?如果每次都获取表格的全部数据进行查找,虽然功能可以实现,但未免效率有些低。

因为id是唯一的,所以可以选择一个中间结构,添加Map数据结构,这样查找起来就会很方便。
.h

cpp 复制代码
QMap<QString, QStandardItem*>   m_mapItem; // 记录已存在的数据

.cpp

cpp 复制代码
// 首先,初始化数据
    qsrand(0); // 随机数

    QStandardItemModel* pModel = new QStandardItemModel;
    for(int i = 0; i < 5; ++i)
    {
        QString strId = QString("uuid_%1").arg(i);
        pModel->setItem(i, 0, new QStandardItem(strId));
        pModel->setItem(i, 1, new QStandardItem(QString("%1_%2").arg(QString::number(i), QString::number(1))));
        pModel->setItem(i, 2, new QStandardItem(QString("%1_%2").arg(QString::number(i), QString::number(2))));
        pModel->setItem(i, 3, new QStandardItem(QString("%1_%2").arg(QString::number(i), QString::number(3))));

		// 将数据添加到容器中
        m_mapItem.insert(strId, pModel->item(i, 0));
    }
    ui->tableView->setModel(pModel);

// 添加或者更新数据,当id存在更新,当id不存在时添加数据
    QStandardItemModel* pModel = static_cast<QStandardItemModel*>(ui->tableView->model());

    int n = qrand()%100 +1;

    QString strUuid = QString("uuid_%1").arg(n);
    if(m_mapItem.contains(strUuid)) // 查找,存在就更新
    {
        QStandardItem* pItem = m_mapItem.value(strUuid);
        int nRow = pItem->row();
        pModel->setItem(nRow, 1, new QStandardItem(QString("%1_%2").arg(QString::number(nRow), QString::number(n))));
        pModel->setItem(nRow, 2, new QStandardItem(QString("%1_%2").arg(QString::number(nRow), QString::number(n))));
        pModel->setItem(nRow, 3, new QStandardItem(QString("%1_%2").arg(QString::number(nRow), QString::number(n))));
        return;
    }
    // 不存在就添加
    int nRowCount = pModel->rowCount();
    pModel->insertRow(nRowCount);
    pModel->setItem(nRowCount, 0, new QStandardItem(QString("%1").arg(strUuid)));
    pModel->setItem(nRowCount, 1, new QStandardItem(QString("%1_%2").arg(QString::number(nRowCount), QString::number(n))));
    pModel->setItem(nRowCount, 2, new QStandardItem(QString("%1_%2").arg(QString::number(nRowCount), QString::number(n))));
    pModel->setItem(nRowCount, 3, new QStandardItem(QString("%1_%2").arg(QString::number(nRowCount), QString::number(n))));
    m_mapItem.insert(strUuid, pModel->item(nRowCount, 0));


// 更新第一行数据
    QStandardItemModel* pModel = static_cast<QStandardItemModel*>(ui->tableView->model());

    int n = qrand()%100 +1;

    QString strUuid = QString("uuid_%1").arg(0);
    if(m_mapItem.contains(strUuid))
    {
        QStandardItem* pItem = m_mapItem.value(strUuid);
        int nRow = pItem->row();
        pModel->setItem(nRow, 1, new QStandardItem(QString("%1_%2").arg(QString::number(nRow), QString::number(n))));
        pModel->setItem(nRow, 2, new QStandardItem(QString("%1_%2").arg(QString::number(nRow), QString::number(n))));
        pModel->setItem(nRow, 3, new QStandardItem(QString("%1_%2").arg(QString::number(nRow), QString::number(n))));
        return;
    }
    int nRowCount = pModel->rowCount();
    pModel->insertRow(nRowCount);
    pModel->setItem(nRowCount, 0, new QStandardItem(QString("%1").arg(strUuid)));
    pModel->setItem(nRowCount, 1, new QStandardItem(QString("%1_%2").arg(QString::number(nRowCount), QString::number(n))));
    pModel->setItem(nRowCount, 2, new QStandardItem(QString("%1_%2").arg(QString::number(nRowCount), QString::number(n))));
    pModel->setItem(nRowCount, 3, new QStandardItem(QString("%1_%2").arg(QString::number(nRowCount), QString::number(n))));

效果

默认ui:

当改变第一行数据时:

当更新或者添加数据时:

如此,问题解决。

结论

对于今天解决不了的事情,也不必着急。因为明天还是解决不了

相关推荐
passionSnail1 分钟前
《用MATLAB玩转游戏开发》推箱子游戏的MATLAB趣味实现
开发语言·游戏·matlab
Once_day24 分钟前
C++之fmt库介绍和使用(1)
开发语言·c++·fmt
摆烂且佛系29 分钟前
FastByteArrayOutputStream和ByteArrayInputStream有什么区别
java·开发语言
Chandler2438 分钟前
Go语言:json 作用和语法
开发语言·golang·json
凤年徐40 分钟前
【C/C++】自定义类型:结构体
c语言·开发语言·c++·经验分享·笔记·算法
能来帮帮蒟蒻吗1 小时前
Python -将MP4文件转为GIF图片
开发语言·python·学习·视频
忆源1 小时前
【Qt】之音视频编程2:QtAV的使用篇
开发语言·qt·音视频
程序员阿鹏1 小时前
Git的安装和配置(idea中配置Git)
java·开发语言·ide·git·intellij-idea·idea
景天科技苑1 小时前
【Rust trait特质】如何在Rust中使用trait特质,全面解析与应用实战
开发语言·后端·rust·trait·rust trait·rust特质
PacosonSWJTU2 小时前
python使用matplotlib画图
开发语言·python·matplotlib