gpt4 book ai didi

c++ - 在 Qt 中使用 SQLite

转载 作者:IT老高 更新时间:2023-10-28 22:27:59 25 4
gpt4 key购买 nike

我正在考虑使用 SQLite 作为我正在编写的 C++ 应用程序的后端数据库。我已经阅读了 trolltech 网站和 sqlite 上的相关文档,但信息似乎有点脱节,没有简单的片段显示完整的 CRUD 示例。

我想编写一组辅助函数,让我可以在我的应用程序中轻松地在 SQLite 中执行 CRUD 操作。

以下 smippet 是我设想编写的辅助函数的伪代码。对于如何“填充” stub 函数的建议,我将不胜感激。特别令人沮丧的一件事是,在任何文档中都没有明确提及查询与运行查询的数据库之间的关系——因此暗示了某种默认连接/表。

在我的应用程序中,我需要能够显式指定运行查询的数据库,因此如果有任何答案说明如何显式指定查询(或其他数据库操作)中涉及的数据库/表,那将很有用就此而言)。

我的伪代码如下:

#include <boost/shared_ptr.hh>

typedef boost::shared_ptr<QSqlDatabase> dbPtr;


dbPtr createConnection(const QString& conn_type = "QSQLITE", const QString& dbname = ":memory:")
{
dbPtr db (new QSQlDatabase::QSqlDatabase());

if (db.get())
{
db->addDatabase(conn_type);
db->setDatabaseName(dbname);

if (!db.get()->open)
db.reset();
}

return db;
}

bool runQuery(const Qstring& sql)
{
//How does SQLite know which database to run this SQL statement against ?
//How to iterate over the results of the run query?
}

bool runPreparedStmtQuery(const QString query_name, const QString& params)
{
//How does SQLite know which database to run this SQL statement against ?
//How do I pass parameters (say a comma delimited list to a prepared statement ?
//How to iterate over the results of the run query?
}

bool doBulkInsertWithTran(const Qstring& tablename, const MyDataRows& rows)
{
//How does SQLite know which database to run this SQL statement against ?
//How to start/commit|rollback
}

如果我的问题不清楚,我想问的是实现上述每个功能的正确方法是什么(可能除了第一个功能 - 当然,除非它可以更好)。

[编辑]

通过删除明确指定表的要求来澄清问题(这已经在 SQL 查询中完成 - 我忘了。感谢 Tom 指出这一点

最佳答案

默认情况下,Qt 使用应用程序的默认数据库来运行查询。那是使用默认连接名称添加的数据库。见 Qt documentation了解更多信息。我不确定您所说的默认数据库表是什么意思,因为要操作的表通常在查询本身中指定?

为了回答您的问题,这里是您的一种方法的实现。请注意,我将返回一个 QSqlQuery 实例,而不是返回一个 bool 实例,以便能够遍历查询的结果。

QSqlQuery runQuery(const Qstring& sql)
{
// Implicitly uses the database that was added using QSqlDatabase::addDatabase()
// using the default connection name.
QSqlQuery query(sql);
query.exec();
return query;
}

您可以按如下方式使用它:

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setHostName("localhost");
db.setDatabaseName("data.db");
if (!db.open())
{
raise ...
}

QSqlQuery query = runQuery("SELECT * FROM user;");
while (query.next())
{
...
}

请注意,也可以通过显式指定相关的 QSqlDatabase 实例作为 QSqlQuery 构造函数的第二个参数来显式指定应针对哪个数据库运行查询:

QSqlDatabase myDb;
...
QSqlQuery query = QSqlQuery("SELECT * FROM user;", myDb);
...

关于c++ - 在 Qt 中使用 SQLite,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2319280/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com