没有日志文件的sqlite3在线备份在正在运行的事务中是否有效
Is a sqlite3 online backup valid in a running transaction without the journal file
我使用sqlite3的备份API为我的sqlite3数据库创建在线备份,如示例2所示。在发生事务时,Sqlite3还向数据库保存了一个日志文件,使回滚成为可能。如果在事务运行时写入备份,似乎会导致问题。
那么,如果在事务运行时创建了备份,那么没有日志文件的备份结果仍然有效吗?我已经做了一些研究,但是找不到任何关于必须做些什么来确保数据库的有效备份的信息。是否要复制日志文件,还是备份API会处理所有事情?
备份使用正常的事务机制访问数据库,因此备份不可能处于不一致状态。(在日志回滚模式下,当其他人正在写时,备份事务将被阻塞;在WAL模式下,备份处于写事务开始前的状态。
相关文章:
- 运行同一解决方案的另一个项目的项目
- CMake-按正确顺序将项目与C运行时对象文件链接
- 如何运行位于boost/libs/python/example/tutorial目录中的hello.cpp和Jamfil
- 代码在main()中运行,但在函数中出现错误
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 如何在运行中期切换GTK CSS style_context
- 如何在MS Visual Studio 2019中运行QT UI
- 如何通过cpp程序运行shell脚本
- IPC使用多个管道和分支进程来运行Python程序
- 删除指向指针的指针是运行时错误吗
- 如何用参数值调用函数(仅在运行时已知)
- 为什么即使使用-cudart-static进行编译,库用户仍然需要链接到cuda运行时
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- c++中的指针和运行时错误
- 在C应用程序中运行C++(带有STL)函数
- 运行程序时出现问题
- 控制允许动态运行c++的并发操作数
- 没有日志文件的sqlite3在线备份在正在运行的事务中是否有效