Sqlite参考手册
C界面 | C Interface
Interrupt A Long-Running Query
void sqlite3_interrupt(sqlite3*);
此函数会导致任何暂挂的数据库操作中止并尽早返回。通常在响应用户操作(例如按下“取消”或Ctrl-C)时调用此例程,用户想要立即停止长查询操作。
从与当前正在运行数据库操作的线程不同的线程调用此例程是安全的。但是,在sqlite3_interrupt()返回之前关闭或可能关闭的数据库连接调用此例程是不安全的。
如果在调用sqlite3_interrupt()时SQL操作几乎完成,那么它可能没有机会被中断并可能继续完成。
被中断的SQL操作将返回SQLITE_INTERRUPT。如果中断的SQL操作是显式事务中的INSERT,UPDATE或DELETE,则整个事务将自动回滚。
在数据库连接D上的所有当前正在运行的SQL语句完成之前,sqlite3_interrupt(D)调用有效。任何在sqlite3_interrupt()调用之后和运行语句到达零之前启动的新SQL语句都会中断,就好像它们在sqlite3_interrupt()调用之前一直运行一样。运行语句计数到零后启动的新SQL语句不受sqlite3_interrupt()的影响。对没有运行SQL语句时发生的sqlite3_interrupt(D)调用是无操作并且对sqlite3_interrupt()调用返回后启动的SQL语句没有影响。
C界面 | C Interface相关
SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源的世界著名数据库管理系统来
主页 | https://sqlite.org/ |
源码 | https://www.sqlite.org/src/ |
发布版本 | 3.21.0 |