我使用C ++的SQLite3 C接口,需要能够确定给定表的存在。有没有直接使用SQL的方法?例如:
bool exists = sqlite3_table_exists("myTable");
是否有任何具有类似功能的功能?
答案 0 :(得分:7)
要检查表是否存在,请检查以下查询是否返回任何行:
SELECT name FROM sqlite_master WHERE type='table' AND name='your_table_name_here'
运行查询&检查是否存在行,这里是代码:
sqlite3_stmt *pSelectStatement = NULL;
int iResult = SQLITE_ERROR;
bool ret = false;
iResult = sqlite3_prepare16_v2(m_pDb, query, -1, &pSelectStatement, 0);
if ((iResult == SQLITE_OK) && (pSelectStatement != NULL))
{
iResult = sqlite3_step(pSelectStatement);
//was found?
if (iResult == SQLITE_ROW) {
ret = true;
sqlite3_clear_bindings(pSelectStatement);
sqlite3_reset(pSelectStatement);
}
iResult = sqlite3_finalize(pSelectStatement);
}
答案 1 :(得分:-1)
另外作为[可能]适用于任何SQL数据库select count(*) from table_that_might_exist limit 1
的替代方案。