如何检查SQLite数据库是否在C/ c++中打开
How can I check if SQLite database is open in C/C++
我希望能够检查给定的SQLite数据库是否打开。我如何在C/c++中做到这一点?我看了一下SQLite C/c++ API,并没有看到明显的用于此目的的东西。
WhozCraig首先提到,您需要检查sqlite3_open
的返回值。如果返回码是SQLITE_OK,说明数据库已经打开。您可能还需要检查指针参数是否未设置为空。
在该函数的接口上有文档。
这是一个邮件列表帖子,有人解释了为什么没有isOpen函数:
顺便说一下,强烈建议使用RAII创建DatabaseHandle类。这样,您的程序将确保在您完成时使用一个应用程序不能使用sqlite3句柄,除非open已经成功,所以有不需要is-opened函数。这不可能,因为Sqlite3_open()分配sqlite3句柄,这意味着客户端不能拥有在sqlite3_open()成功之前,一个有效的句柄。看看有没有打开检查指针是否为NULL(当然必须初始化)是,否则它有一个未指定的值)。
…
关闭后,再次将其赋值为NULL,这就是你的"is open"国旗。
sqlite3
对象调用sqlite3_close
。来自sqlite3_open
的文档:
打开时是否发生错误,关联的资源与数据库连接句柄应该通过传递它来释放当不再需要sqlite3_close()时。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C/C++预处理器是否可以检测一些编译器选项
- 是否可以用"iostream"包装现有的TCP/OOpenSSL会话