linux qt引入sqlite3,linux - 在QT下打开现有的sqlite3数据库 - 堆栈内存溢出

没有参数的QSqlQuery构造函数为您的应用程序使用默认数据库。 可能尚未设置。 使用构造函数指定查询要使用的数据库:

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE", "connection_name");

// Open db...

QSqlQuery query(db);

if (!query.exec(...)) {

// ...

}

// ...

请注意之后如何关闭连接。

编辑:这是我刚刚编写的测试,正在我的系统上工作。 您可能要尝试。

#include

#include

#include

#include

int main(int argc, char *argv[])

{

// Create database.

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE", "Connection");

db.setDatabaseName("/tmp/test.db");

if (!db.open()) {

qDebug("Error occurred opening the database.");

qDebug("%s.", qPrintable(db.lastError().text()));

return -1;

}

// Insert table.

QSqlQuery query(db);

query.prepare("CREATE TABLE IF NOT EXISTS test (id INTEGER PRIMARY KEY, text TEXT)");

if (!query.exec()) {

qDebug("Error occurred creating table.");

qDebug("%s.", qPrintable(db.lastError().text()));

return -1;

}

// Insert row.

query.prepare("INSERT INTO test VALUES (null, ?)");

query.addBindValue("Some text");

if (!query.exec()) {

qDebug("Error occurred inserting.");

qDebug("%s.", qPrintable(db.lastError().text()));

return -1;

}

// Query.

query.prepare("SELECT * FROM test");

if (!query.exec()) {

qDebug("Error occurred querying.");

qDebug("%s.", qPrintable(db.lastError().text()));

return -1;

}

while (query.next()) {

qDebug("id = %d, text = %s.", query.value(0).toInt(),

qPrintable(query.value(1).toString()));

}

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值