QTableview + MySQL 分页查询实现记录

一、如何把查询结果分页返回
1.把查询结果放到一个零时表中
先建立一个新表temcity,把city的字段完全复制到temcity。
清空temcity表。

truncate table temcity

使用以下语句先进行 “查询->赋值” 操作:

INSERT INTO temcity SELECT * FROM city WHERE pllh = 'condition'

把表city中pllh = ‘condition’的所有条目都插入到了表temcity中。
2.查temcity表,限制返回的条目数量,以及其开始的坐标,比如返回从坐标0开始之后的1000条数据:

SELECT * FROM temcity limit 0,1000

作为第一页,返回从坐标1000开始之后的1000条数据作为第二页:

SELECT * FROM temcity limit 1000,1000

3.获得temcity中的数据总条数:

QString strres = QString("SELECT * FROM temcity WHERE pllh like pllh");
QSqlError lastError;
bool successres = querysql.exec(strres);
if(successres){
    while(querysql.next()){
        IDlist.append(querysql.value(1).toString());
    }
    totalSize = IDlist.size();




二、界面上刷新显示对应页内容的方法。
1.Qtableview使用方法。
先在ui文件添加一个Qtableview,然后新建数据模型,设置列名。

model = new QStandardItemModel();
    ui->tableView->setModel(model);
    ui->tableView->horizontalHeader()->setDefaultAlignment(Qt::AlignHCenter);
    ui->tableView->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);
    ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);
    model->setColumnCount(7);
    model->setHeaderData(0,Qt::Horizontal,QString::fromLocal8Bit("1"));
    model->setHeaderData(1,Qt::Horizontal,QString::fromLocal8Bit("2"));
    model->setHeaderData(2,Qt::Horizontal,QString::fromLocal8Bit("3"));
    model->setHeaderData(3,Qt::Horizontal,QString::fromLocal8Bit("3"));
    model->setHeaderData(4,Qt::Horizontal,QString::fromLocal8Bit("4"));
    model->setHeaderData(5,Qt::Horizontal,QString::fromLocal8Bit("5"));
    model->setHeaderData(6,Qt::Horizontal,QString::fromLocal8Bit("6"));

查数据库,先刷新model

        model->clear();//刷新model

把数据库返回的数据填到Qtableview里

            QString strfirstpage = QString("SELECT * FROM temcity limit 0,1000");
            bool successrFirstpage = querysql.exec(strfirstpage);
            if(successrFirstpage){
                while (querysql.next()) {
                    pllhlist.append(querysql.value(1).toString());
                    dhlist.append(querysql.value(2).toString());
                    czlist.append(querysql.value(3).toString());
                    zllist.append(querysql.value(4).toString());
                    hang.append(querysql.value(5).toString());
                    lie.append(querysql.value(6).toString());
                    timelist.append(querysql.value(7).toString().replace("T"," "));
                }
                model->setColumnCount(7);
                model->setHeaderData(0,Qt::Horizontal,QString::fromLocal8Bit("坯料炉号"));
                model->setHeaderData(1,Qt::Horizontal,QString::fromLocal8Bit("锭号"));
                model->setHeaderData(2,Qt::Horizontal,QString::fromLocal8Bit("材质"));
                model->setHeaderData(3,Qt::Horizontal,QString::fromLocal8Bit("重量"));
                model->setHeaderData(4,Qt::Horizontal,QString::fromLocal8Bit("行"));
                model->setHeaderData(5,Qt::Horizontal,QString::fromLocal8Bit("列"));
                model->setHeaderData(6,Qt::Horizontal,QString::fromLocal8Bit("时间日期"));


                for(int i = 0; i < pllhlist.size(); i++)
                 {
                    
                     model->setItem(i,0,new QStandardItem(pllhlist[i]));
                     model->setItem(i,1,new QStandardItem(dhlist[i]));
                     model->setItem(i,2,new QStandardItem(czlist[i]));
                     model->setItem(i,3,new QStandardItem(zllist[i]));
                     model->setItem(i,4,new QStandardItem(hang[i]));
                     model->setItem(i,5,new QStandardItem(lie[i]));
                     model->setItem(i,6,new QStandardItem(timelist[i]));

                 }
            }
        

这句就是分页查询的关键:
QString strfirstpage = QString(“SELECT * FROM temcity limit 0,1000”);

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现时间策略表格,你可以使用 QTableView 和自定义委托来实现。 首先,你需要创建一个 QTableView 实例,并将其设置为可编辑。然后,你需要创建一个自定义委托来处理表格中单元格的显示和编辑。 下面是一个简单的示例代码,演示如何创建一个时间策略表格: ```python from PyQt5.QtWidgets import QApplication, QTableView, QAbstractItemView, QHeaderView from PyQt5.QtGui import QStandardItemModel, QStandardItem from PyQt5.QtCore import Qt, QTime class TimePolicyDelegate(QtWidgets.QStyledItemDelegate): def createEditor(self, parent, option, index): editor = QtWidgets.QTimeEdit(parent) editor.setDisplayFormat("hh:mm") return editor def setEditorData(self, editor, index): value = index.model().data(index, Qt.EditRole) time = QTime.fromString(value, "hh:mm") editor.setTime(time) def setModelData(self, editor, model, index): time = editor.time() model.setData(index, time.toString("hh:mm"), Qt.EditRole) class TimePolicyTableView(QTableView): def __init__(self, parent=None): super().__init__(parent) self.setEditTriggers(QAbstractItemView.DoubleClicked) self.setSelectionBehavior(QAbstractItemView.SelectRows) self.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch) self.verticalHeader().setVisible(False) self.setItemDelegate(TimePolicyDelegate(self)) self.setModel(QStandardItemModel()) self.model().setColumnCount(2) self.model().setHeaderData(0, Qt.Horizontal, "时间段") self.model().setHeaderData(1, Qt.Horizontal, "策略") def addTimePolicy(self, time, policy): row = self.model().rowCount() self.model().setItem(row, 0, QStandardItem(time.toString("hh:mm"))) self.model().setItem(row, 1, QStandardItem(policy)) ``` 这个示例代码创建了一个名为 TimePolicyTableView 的自定义 QTableView 子类。它使用 QStandardItemModel 来存储时间策略表格中的数据,并使用 QHeaderView 和 QAbstractItemView 来设置表格的外观和行为。 自定义委托 TimePolicyDelegate 负责将时间数据显示为 QTimeEdit 控件,并将其转换回字符串格式,以便在模型中存储。 你可以使用 addTimePolicy 方法来向表格中添加时间策略。该方法将时间和策略作为参数,并将其插入到模型的新行中。 最后,你可以在主函数中创建 TimePolicyTableView 的实例,并将其添加到应用程序中。例如: ```python if __name__ == "__main__": app = QApplication(sys.argv) table = TimePolicyTableView() table.addTimePolicy(QTime(8, 0), "开门") table.addTimePolicy(QTime(12, 0), "关门") table.addTimePolicy(QTime(13, 0), "开门") table.addTimePolicy(QTime(17, 0), "关门") table.show() sys.exit(app.exec_()) ``` 这将创建一个简单的时间策略表格,其中包含四个时间段和相应的策略。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值