SQLite3 C 接口:如何确定表的存在

SQLite3 C interface: how to determine existence of a table

本文关键字:存在 何确定 接口 SQLite3      更新时间:2023-10-16

我正在使用C++的SQLite3 C接口,需要能够确定给定表的存在。有没有办法在不直接使用 SQL 的情况下做到这一点?例:

bool exists = sqlite3_table_exists("myTable");

是否有具有类似功能的功能?

若要检查表是否存在,请检查以下查询是否返回任何行:

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);
}

也可以作为替代方案,[可能]适用于任何 SQL 数据库select count(*) from table_that_might_exist limit 1