QSqlQuery last 不起作用
QSqlQuery last not working
我正在尝试在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((?
相关文章:
- 我的神经网络不起作用 [XOR 问题]
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- C++为什么尽管我调用了void函数,它却不起作用
- 为什么在保护模式下继承升级不起作用
- 循环在计数器中不起作用
- 在其他文件中创建类时在 c++ 项目中不起作用
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- 为什么二进制搜索在我的测试中不起作用
- 我的代码中有错误吗?使用BGI图形的C++代码对我不起作用
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 带有指定长度字符* 参数的 std::regex_search 在 VS2017 中不起作用?
- Bjarne Stroustrup Book - std_lib_facilities.h - 不起作用(未知类型名称)
- 为什么简单的算术减法在"if"条件下不起作用?
- 为什么Stroustup书中的has_f不起作用
- 你能检查一下为什么在这个代码中从链接列表中删除项目不起作用吗
- 嵌套While循环不起作用(C++问题)
- C++Matching Brackets 2解决方案不起作用
- 为什么这段代码不起作用,我该如何解决?
- QSqlQuery last 不起作用