QSqlQuery last 不起作用

QSqlQuery last not working

本文关键字:不起作用 last QSqlQuery      更新时间:2023-10-16

我正在尝试在SQLite中获取已执行查询的大小,但是当我使用last并尝试使用last时,它总是假

的这是我尝试执行的代码

void createDB() {
  QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE","CREATE_CON");
  db.setDatabaseName("C:/Desktop/TestDb.db3");
  db.open();
  QSqlQuery q(db);
  q.exec("CREATE TABLE IF NOT EXISTS Test(testCol TEXT PRIMARY KEY);");
}
int entries() {
  QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE","SELECT_CON");
  db.setDatabaseName("C:/Desktop/TestDb.db3");
  db.open();
  QSqlQuery q(db);
  q.exec("SELECT * FROM Test;");
  if(q.last() == false) {
    qDebug()<<q.lastError().text();
    qDebug()<<db.lastError().text();
  }
  return q.at()+1;
}

得到的错误文本是空的,所以我不知道我做错了什么。
我可以很好地创建数据库,以便我的数据库实例正常工作。

操作系统: 视窗 10
我正在使用: Qt 5.10.1
编译器:MinGW

行为

是正确的,如果你的表是空的,就不会有最后一个元素,所以last()将是假的。

我将用这个问题向您展示您必须验证所有可能的错误。一个程序有时可以工作,但一个好的程序员的职责是防止它总是工作。

#include <QApplication>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QSqlError>
#include <QDebug>
#include <QPushButton>
static bool createDB() {
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE","CREATE_CON");
    db.setDatabaseName("TestDb.db3");
    if(!db.open()){
        qDebug()<<db.lastError().text();
        return false;
    }
    QSqlQuery q(db);
    if(!q.exec("CREATE TABLE IF NOT EXISTS Test(testCol TEXT PRIMARY KEY);")){
        qDebug()<<q.lastError().text();
        return false;
    }
    return true;
}
static int entries() {
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE","SELECT_CON");
    db.setDatabaseName("TestDb.db3");
    if(!db.open()){
        qDebug()<< db.lastError().text();
        return -1;
    }
    QSqlQuery q(db);
    if(!q.exec("SELECT * FROM Test;")){
        qDebug()<<q.lastError().text();
        return -2;
    }
    if(!q.last()) {
        return 0;
    }
    qDebug()<<"not empty";
    return q.at()+1;
}
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    if(!createDB()){
        return -1;
    }
    QPushButton button("call entries");
    QObject::connect(&button, &QPushButton::clicked, [&](){
        qDebug()<<entries();
    });
    button.show();
    return a.exec();
}

而不是 :

q.exec("SELECT * FROM Test;");
if(q.last() == false) {
    qDebug()<<q.lastError().text();
    qDebug()<<db.lastError().text();
}

你应该做:

if(!q.exec("SELECT * FROM Test;")) {
    qDebug()<<q.lastError().text();
}

如果你想知道查询的大小,为什么不把它存储在一个QString中,并在需要时调用QString::length((?