【发布时间】:2013-11-26 16:02:51
【问题描述】:
使用带有 sqlite (v 3.7.13) 的 C api,我正在尝试列出当前连接的所有附加数据库:
sqlite3_stmt* pCompiledSql;
if(SQLITE_OK == sqlite3_prepare_v2(database, "PRAGMA database_list;", -1, &pCompiledSql, nullptr))
{
while(SQLITE_ROW == sqlite3_step(pCompiledSql))
{
const char* pName = reinterpret_cast<const char*>(sqlite3_column_text(pCompiledSql, 1));
const char* pFile = reinterpret_cast<const char*>(sqlite3_column_text(pCompiledSql, 2));
// Using pName and PFile...
}
}
其中 database 是连接了多个数据库的现有数据库的句柄。相同的代码适用于诸如“SELECT * FROM testtable;”之类的语句。
但是,使用 pragma 调用,第一步调用只会立即返回 SQLITE_DONE。
我很确定我忽略了一些明显但没有太多 SQLite 经验的我现在卡住了......这里可能出了什么问题?
【问题讨论】:
-
该代码对我有用。
-
感谢您的确认,它帮助很大。所以如果上面的代码没问题,问题一定出在数据库的某个地方。无论如何,我必须继续前进并找到一种解决方法(我在附加数据库时保存了附加数据库的源路径和名称。)。再次感谢您的努力。