int QSqlQuery::size() const

函数注释: 

中文注释: 

如果  (大小不能被决定  或者 数据库不支持报告查询的大小信息)        : 返回-1

否则    :返回结果的大小(查询出来的记录行数)         

注意:

对于非查询语句(isSelect()返回false):将返回-1

如果查询不是活跃的(isActive())        :将返回-1.

为了确定非查询语句影响的行数,请使用numRowsAffected().

情况1:

之前在查询达梦数据库的数据时,使用该函数返回-1.

现在猜测应该是达梦数据库不支持报告查询的大小信息

情况2:

与MySQL进行交互时,使用该接口,可以查询到相关信息。

            QSqlQuery query(m_database);
            query.exec("SELECT * FROM test;");
            while(query.next())
                str += query.value(0).toString() + "|";
            qDebug()<<__FILE__<<"["<<__LINE__<<"]"<<query.size();

打印出的信息: 

debug\../../demo/widget.h [ 48 ] 1200

与数据库中信息进行对照: 

情况3:

与Sqlite交互时,测试也不支持报告查询的大小信息

        QSqlQuery query(database);
        query.exec("select * from menu");
        if (!query.exec())
        {
            qDebug() << "Error:" << query.lastError();
        }
        else {
            while (query.next())
            {
                qDebug() << query.value("name").toString();
            }
            qDebug() << query.size();
        }

结果是-1

实际的记录数:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lpl还在学习的路上

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值