当我在空数据库上调用sqlite3_prepare_v2(CREATE TABLE)时,你知道为什么我会得到“Library Routine Called Out of Sequence”吗?
我创建一个空数据库,然后打开它.后来我保存了所有必须写入RAM中的数据库的信息(我需要将该信息保存在RAM中并在执行结束时将其刷新到永久存储器),但是当我调用sqlite3_prepare_v2(创建表)时,我收到此错误消息).它返回“Library Routine Called Out of Sequence”作为错误消息.
我确实正确地打开了我的数据库(我认为这可能是一个问题,所以我关闭()我的数据库然后在调用sqlite3_prepare_v2(CREATE TABLE)之前打开().我认为这可能是因为线程并发,但使用临界区也没有帮助.
这就是
documentation所说的错误原因:
- Calling any API routine with an sqlite3* pointer that was not
obtained from sqlite3_open() or sqlite3_open16() or which has
already been closed by sqlite3_close().- Trying to use the same database connection at the same instant in
time from two or more threads.- Calling sqlite3_step() with a sqlite3_stmt* statement pointer that
was not obtained from sqlite3_prepare() or sqlite3_prepare16() or
that has already been destroyed by sqlite3_finalize().- Trying to bind values to a statement (using sqlite3_bind_…()) while that statement is running.
你提到尝试一个关键部分,所以我想我们可以排除#2.您的错误是调用sqlite3_prepare_v2(…)而不是sqlite3_step()或sqlite3_bind()的结果,所以我猜这只会留下#1?你能仔细检查一下你的db指针好吗?将其追溯到返回它的sqlite3_open()并确保在调用prepare之前没有关闭它?
这对我有用:
#include <stdio.h> #include <sqlite3.h> int main(int argc,char **argv){ sqlite3 *db; int rc; char *db_name= ":memory:"; rc = sqlite3_open(db_name,&db); if (rc != sqlITE_OK) { fprintf(stderr,"Failed to open in memory database: %s\n",sqlite3_errmsg(db)); sqlite3_close(db); return(1); } const char *create_sql = "CREATE TABLE foo(bar TEXT)"; sqlite3_stmt *statement; rc = sqlite3_prepare_v2(db,create_sql,-1,&statement,NULL); if (rc != sqlITE_OK) { fprintf(stderr,"Failed to prepare statement: %s\n",sqlite3_errmsg(db)); sqlite3_close(db); return(1); } rc = sqlite3_step(statement); if (rc == sqlITE_ERROR) { fprintf(stderr,"Failed to execute statement: %s\n",sqlite3_errmsg(db)); } sqlite3_close(db); }