- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 Qt 框架连接到 sql 数据库。
不幸的是,db.open() 总是返回 true(您可以设置任何密码、主机名等...),尽管没有建立连接(?)。我从对数据库没有任何影响的查询中得出这一点。
我在 Ubuntu 14.04 上使用 LAMPP。
我有以下代码:
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QApplication>
#include <QSql>
#include <QSqlDatabase>
#include <QMessageBox>
#include <QSqlQuery>
void MainWindow::on_ButtonSQL_clicked()
{
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE", "con1");
db.setHostName("localhost");
db.setDatabaseName("kinectshop2015");
db.setUserName("root");
db.setPassword("");
QMessageBox msgBox;
if (db.open()) {
msgBox.setText("Yay! Your database host is "+db.hostName()+" .\n"+" The name of the database is "+db.databaseName()+".");
msgBox.exec();
}
QSqlQuery query;
query.exec("INSERT INTO users (id, username, balance, isAdmin)" "VALUES(3, 'somebody', 10000, 1)");
}
最佳答案
一个问题是您要指定连接名称。
QSqlDatabase QSqlDatabase::addDatabase(const QString & type, const QString & connectionName = QLatin1String( defaultConnection ))
If connectionName is not specified, the new connection becomes the default connection
鉴于您的数据库连接不是默认连接,您需要告诉 QSqlQuery 使用哪个数据库,即
QSqlQuery query(db);
query.exec("INSERT INTO users (id, username, balance, isAdmin)" "VALUES(3, 'somebody', 10000, 1)");
另一个“问题”是使用 sqlite 你总是通过你正在调用的来创建一个新的数据库,因此问题不是数据库没有打开而是它的内容不正确(因为如果您指定了一个不存在的文件名)。如果我拿走你的代码并添加
qDebug() << query.lastError();
在 query.exec
之后它正确地提示
QSqlError(1, "Unable to execute statement", "no such table: users")
如果我在插入查询之前包含一个创建表的语句
QSqlQuery createTable("create table users ( id INTEGER, username TEXT, balance REAL, isAdmin INTEGER)",db);
createTable.exec();
我在新创建的 db 文件中正确地获取了该表,并且它具有您要插入的条目。
这有帮助吗?
关于c++ - QSqlDatabase::open() 总是返回 true,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30139103/
我已经创建了一个肯定存在于项目目录中的数据库,我可以使用 DBBrowser 和 Ubuntu 终端打开它。它们都显示数据库包含“电影”表,但我在 C++ 中的代码说找不到这样的表 QSqlDatab
我只有一个与数据库的连接,用于我正在开发的库存应用程序。 我现在正在做的是每次需要对 dB 进行查询时调用 open(),然后执行 close()。 这样做比仅仅打开连接并保持打开状态有什么好处吗?
我需要在本地系统上存储一些值并稍后以表格格式访问它,所以我选择了 QSqlDatabase。首先我必须检查数据库是否已经存在。但是使用下面的代码我总是收到消息 Data base not exist
from PyQt4 import QtGui,QtSql def start_prestige(): m_name = "Prestige" m_desc = "
为什么下面的代码打印的是 true 而不是 false? int main(int argc, char *argv[]) { QApplication a(argc, argv);
基于 Qt 文档: A connection can only be used from within the thread that created it. Moving connections b
我正在运行来自 http://www.python.org/getit/ 的 python 2.7.3 (python-2.7.3.amd64.msi) 我使用的安装程序来自:http://www.l
我正在使用 QSqlDatabase 并试图找到一种方法来终止正在运行的查询(这是我正在编写的 sql 客户端的一种必要功能) 有没有办法获取正在运行的查询的 ID? (计划只是在另一个连接中执行 k
很多QSqlDatabase的教程都是这样启动数据库的: QSqlDatabase cn = QSqlDatabase::addDatabase("QSQLITE",QString::number(i
我有一个 Qt 应用程序,它(本质上)使用 QSqlDatabase 创建一个 QMYSQL 数据库连接,创建一个 gridPopulator 实例来填充一个 QTableView 带有(显然)来自数
处理 QSqlDatabase 连接的正确方法是什么? 在我的程序中我是这样做的: DatabaseConnector *databaseConnector = 0; try { databa
我有依赖类和独立类,我需要在这些类中创建数据库连接。据我了解Qt documentation ,如果我以默认方式创建连接,则所有连接都使用相同的连接。 我应该为不同的类创建不同的数据库连接,还是应该使
我对手册感到困惑,我应该这样工作吗: { QSqlDatabase db = QSqlDatabase::addDatabase (...); QSqlQuery query (db); que
我有一个多年来一直运行良好的功能,开始 QSqlDatabase DBUtil :: basic_open (const QString & path) { static int connec
在我的开发电脑中,“QSqlDatabase ob”行不会崩溃并且工作得很好。但是在一台新的电脑上移动了 exe,它崩溃了,但是如果我注释上面的行并再次准备 exe,它就可以正常运行。 所以我在新电脑
我刚刚完成了 QT CRUD 应用程序的开发。我使用 SQLite 将信息本地存储在运行应用程序的磁盘中。这样我的应用程序就可以正常工作了。 但是该应用程序缺少中央数据库服务器。因此,我首先安装 My
将 Qt 从 5.5 更新到 5.6 后,QSqlDatabase:open 始终返回 true - 即使主机不可访问和/或用户名/密码/数据库设置设置为无意义。 测试代码: QSqlDatabase
文件对此只字不提。我只是想知道 exec() 调用是否阻塞?意思是,如果我先创建一个表,然后启动一个线程,在线程中我调用一个对我刚创建的表的查询。 是否有可能在实际建表之前调用查询? 最佳答案 是的,
我正在尝试使用 .open() 函数在 QT 中打开一个 sqlite 数据库文件,如果文件没有退出,.open() 不会返回 false,它只是在给定的位置创建一个新文件目录。我的代码: QSqlD
我正在做一个使用 QSqlDatabase 的项目。现在我正在使用 QtConcurrent (QFuture) 来执行任何 SQL 命令。 现在,使用 QFuture 运行的每个新命令都会创建新的
我是一名优秀的程序员,十分优秀!