SQLite C语言接口中的许多例程都返回数字结果代码,它们指示成功或失败,并且在失败的情况下,提供了一些导致失败的原因的想法。本文档致力于解释每个数字结果代码的含义。
“错误代码”是“结果代码”的子集,表示发生了问题。只有少数几个非错误的结果代码: SQLITE_OK,SQLITE_ROW和SQLITE_DONE。术语“错误代码”表示除这三个以外的任何结果代码。
结果代码是带符号的32位整数。结果代码的最低有效8位定义了一个宽泛的类别,称为“主要结果代码”。更高的有效位提供了有关错误的更详细的信息,称为“扩展结果代码”
请注意,主要结果代码始终是扩展结果代码的一部分。给定完整的32位扩展结果代码,应用程序始终仅可以通过提取扩展结果代码的最低有效8位来找到相应的主要结果代码。
所有扩展结果代码也是错误代码。因此,术语“扩展结果代码”和“扩展错误代码”是可以互换的。
为了实现历史兼容性,默认情况下,C语言接口返回主要结果代码。可以使用sqlite3_extended_errcode()接口检索最新错误的扩展结果代码。所述sqlite3_extended_result_codes()接口可用于把一个数据库连接到那里返回扩展结果代码,而不是主要结果代码的模式。
所有结果代码均为整数。所有结果代码的符号名称都是使用sqlite3.h头文件中的“ #define”宏创建的。sqlite3.h头文件中有单独的部分,用于结果代码定义和扩展的结果代码定义。
主要结果代码符号名称的格式为“ SQLITE_XXXXXX”,其中XXXXXX是大写字母字符的序列。扩展结果代码名称的格式为“ SQLITE_XXXXXX_YYYYYYY”,其中XXXXXX部分是相应的主要结果代码,而YYYYYYY是对结果代码进行进一步分类的扩展名。
现有结果代码的名称和数值是固定不变的。但是,新的结果代码,尤其是新的扩展结果代码,可能会出现在SQLite的未来版本中。
31个结果代码在sqlite3.h中 定义,并按字母顺序列出如下:
71个扩展结果代码在sqlite3.h中定义,并按字母顺序在下面列出:
SQLITE_OK结果代码表示操作成功,没有错误。大多数其他结果代码表示错误。
SQLITE_ERROR结果代码是通用错误代码,在没有其他更特定的错误代码可用时使用。
SQLITE_INTERNAL结果代码指示内部故障。在SQLite的工作版本中,应用程序永远不应看到此结果代码。如果应用程序确实遇到此结果代码,则表明数据库引擎中存在错误。
SQLite当前不生成此结果代码。但是,应用程序定义的SQL函数或 虚拟表,VFSes或其他扩展名可能导致返回此结果代码。
SQLITE_PERM结果代码指示无法为新创建的数据库提供请求的访问模式。
SQLITE_ABORT结果代码指示操作在完成之前已中止,通常是应用程序请求。另请参见:SQLITE_INTERRUPT。
如果sqlite3_exec()的回调函数返回非零值,则sqlite3_exec()将返回SQLITE_ABORT。
如果与挂起的读取或写入操作在同一数据库连接上发生ROLLBACK操作,则挂起的读取或写入操作可能会失败,并显示SQLITE_ABORT或SQLITE_ABORT_ROLLBACK错误。
除了作为结果代码之外,SQLITE_ABORT值还用作 从sqlite3_vtab_on_conflict()接口返回的冲突解决模式。
SQLITE_BUSY结果代码指示由于某些其他数据库连接(通常是单独过程中的数据库连接)的并发活动而无法写入(或在某些情况下读取)数据库文件。
例如,如果进程A在大型写事务中,并且进程B同时尝试启动新的写事务,则进程B将返回SQLITE_BUSY结果,因为SQLite一次仅支持一个写程序。进程B将需要等待进程A完成其事务,然后才能开始新事务。该 sqlite3_busy_timeout()和sqlite3_busy_handler()接口和busy_timeout编译可用来,以帮助它处理SQLITE_BUSY错误进程B。
在事务中的任何时候都可能发生SQLITE_BUSY错误:首次启动事务时,任何写入或更新操作期间或事务提交时。为了避免在事务中间遇到SQLITE_BUSY错误,应用程序可以使用BEGIN IMMEDIATE而不是仅使用BEGIN来启动事务。将立即开始命令本身可能返回SQLITE_BUSY,但如果它成功,那么SQLite的保证,通过未来在同一个数据库上没有后续操作COMMIT 将返回SQLITE_BUSY。
另请参见: SQLITE_BUSY_RECOVERY和SQLITE_BUSY_SNAPSHOT。
SQLITE_BUSY结果代码与SQLITE_LOCKED的不同之处在于,SQLITE_BUSY表示与单独的数据库连接发生冲突,可能是在单独的进程中发生,而SQLITE_LOCKED 表示在同一数据库连接中发生冲突(或者有时是具有共享缓存的数据库连接)。
SQLITE_LOCKED结果代码指示由于同一数据库连接内的冲突或与使用共享缓存的其他数据库连接之间的冲突,写操作无法继续。
例如,当另一个线程正在同一数据库连接上从该表读取数据时,不能运行DROP TABLE语句,因为删除该表会从并发阅读器下删除该表。
SQLITE_LOCKED结果代码与SQLITE_BUSY的不同之处在于,SQLITE_LOCKED指示同一数据库连接 (或与共享缓存的连接)上的冲突,而SQLITE_BUSY指示与其他数据库连接的冲突(可能在不同的过程中)。
SQLITE_NOMEM结果代码指示SQLite无法分配完成操作所需的所有内存。换句话说,在需要分配内存以继续操作的情况下,对sqlite3_malloc()或sqlite3_realloc()的内部调用失败。
尝试更改某些当前数据库连接不具有写许可权的数据时,将返回SQLITE_READONLY结果代码。
SQLITE_INTERRUPT结果代码指示操作被sqlite3_interrupt()接口中断。另请参阅:SQLITE_ABORT
SQLITE_IOERR结果代码表示操作无法完成,因为操作系统报告了I / O错误。
完整的磁盘驱动器通常会显示SQLITE_FULL错误,而不是SQLITE_IOERR错误。
I / O错误有许多不同的扩展结果代码,用于标识失败的特定I / O操作。
SQLITE_CORRUPT结果代码指示数据库文件已损坏。有关如何发生损坏的更多讨论,请参见如何损坏数据库文件。
SQLITE_NOTFOUND结果代码在两个上下文中使用。sqlite3_file_control()接口可以返回SQLITE_NOTFOUND,以指示基础VFS无法识别作为第三个参数传递的文件控件操作码。sqlite3_vfs对象的xSetSystemCall()方法也可以返回SQLITE_NOTFOUND 。
SQLite实现也在内部使用SQLITE_NOTFOUND结果代码,但是这些内部使用不会暴露给应用程序。
SQLITE_FULL结果代码指示由于磁盘已满而无法完成写入。请注意,在尝试将信息写入主数据库文件时,可能会发生此错误,或者在写入临时磁盘文件时,也可能会发生此错误。
有时,即使存在大量的主磁盘空间,应用程序也会遇到此错误,因为在将临时文件存储在单独的分区上的系统上写入临时磁盘文件时,会发生此错误,而临时文件存储在比主磁盘少的空间上。
SQLITE_CANTOPEN结果代码指示SQLite无法打开文件。有问题的文件可能是主数据库文件,也可能是几个临时磁盘文件之一。
SQLITE_PROTOCOL结果代码指示SQLite使用的文件锁定协议有问题。当前仅在使用WAL模式并尝试启动新事务时返回SQLITE_PROTOCOL错误。当两个单独的数据库连接都尝试在WAL模式下同时启动事务时,可能会发生争用情况 。短暂的延迟后,比赛的失败者退回并重试。如果同一连接在几秒钟的时间内失去了数十次锁定竞争,它将最终放弃并返回SQLITE_PROTOCOL。实际上,SQLITE_PROTOCOL错误应该非常非常少地出现,并且仅当有许多单独的进程都在激烈竞争以写入同一数据库时才出现。
SQLITE_SCHEMA结果代码指示数据库架构已更改。对于使用sqlite3_prepare()或 sqlite3_prepare16()生成的准备好的语句,可以从sqlite3_step()返回此结果代码。如果在准备该语句的时间与运行该语句的时间之间,数据库架构被其他进程更改,则可能会导致此错误。
如果从sqlite3_prepare_v2()生成了一条准备好的语句,则如果架构发生更改,该语句将自动重新准备,最多 SQLITE_MAX_SCHEMA_RETRY次(默认值:50)。在sqlite3_step() 接口将只返回SQLITE_SCHEMA返回给应用程序,如果这些多次重试后故障仍然存在。
SQLITE_TOOBIG错误代码指示字符串或BLOB太大。SQLite中字符串或BLOB的默认最大长度为1,000,000,000字节。可以在编译时使用SQLITE_MAX_LENGTH编译时选项更改最大长度,或在运行时使用sqlite3_limit(db,SQLITE_LIMIT_LENGTH,...)接口更改此最大长度。当SQLite遇到超过编译时或运行时限制的字符串或BLOB时,将导致SQLITE_TOOBIG错误。
将超大的SQL语句传递到sqlite3_prepare_v2()接口之一时,也会导致SQLITE_TOOBIG错误代码。SQL语句的最大长度默认为1,000,000字节的小得多的值。可以在编译时使用SQLITE_MAX_SQL_LENGTH或在运行时使用sqlite3_limit(db,SQLITE_LIMIT_SQL_LENGTH等)设置最大SQL语句长度。
SQLITE_CONSTRAINT错误代码表示在尝试处理SQL语句时发生了违反SQL约束的情况。有关失败约束的其他信息,可以通过查询附带的错误消息(通过sqlite3_errmsg()或 sqlite3_errmsg16()返回)或通过查看扩展的错误代码来找到。
SQLITE_CONSTRAINT代码也可以用作虚拟表实现的xBestIndex()方法的返回值。当xBestIndex()返回SQLITE_CONSTRAINT时,这表示提交到xBestIndex()的特定输入组合不能产生可用的查询计划,因此不应作进一步考虑。
SQLITE_MISMATCH错误代码指示数据类型不匹配。
SQLite通常非常宽容值类型与要存储该值的容器的声明类型之间的不匹配。例如,SQLite允许应用程序将大型BLOB存储在声明类型为BOOLEAN的列中。但是在少数情况下,SQLite对类型严格。在少数情况下,如果类型不匹配,则会返回SQLITE_MISMATCH错误。
表 的rowid必须为整数。尝试将rowid设置为非 整数(或NULL,它将自动转换为下一个可用的整数rowid)以外的任何值,将导致SQLITE_MISMATCH错误。
如果应用程序以未定义或不受支持的方式使用任何SQLite接口,则可能返回SQLITE_MISUSE返回代码。例如,在该准备好的语句完成之后使用准备好的语句可能会导致SQLITE_MISUSE错误。
SQLite尝试使用此结果代码来检测滥用并报告滥用情况。但是,不能保证成功检测到滥用情况。滥用检测是概率性的。应用程序永远不要依赖于SQLITE_MISUSE返回值。
如果SQLite曾经从任何接口返回SQLITE_MISUSE,则意味着该应用程序编码不正确,需要进行修复。请勿发布有时会从标准SQLite接口返回SQLITE_MISUSE的应用程序,因为该应用程序包含潜在的严重错误。
当数据库变得大于文件系统可以处理的大小时,在不支持大文件的系统上可能会返回SQLITE_NOLFS错误。“ NOLFS”代表“不支持大文件”。
当授权者回调指示未授权正在准备的SQL语句时,将返回SQLITE_AUTH错误 。
所述SQLITE_RANGE错误索引,参数号参数传递给之一sqlite3_bind例程或在一个列号sqlite3_column 例程是超出范围。
尝试打开文件时,SQLITE_NOTADB错误表明正在打开的文件似乎不是SQLite数据库文件。
任何C / C ++接口都不会返回SQLITE_NOTICE结果代码。但是,有时在sqlite3_log()回调中将SQLITE_NOTICE(或更确切地说是其扩展的错误代码之一)用作第一个参数,以指示发生了异常操作。
任何C / C ++接口都不返回SQLITE_WARNING结果代码。但是,有时将SQLITE_WARNING(或其扩展错误代码中的一个)用作sqlite3_log()回调中的第一个参数,以指示发生了异常且可能不明智的操作。
sqlite3_step() 返回的SQLITE_ROW结果代码 指示输出的另一行可用。
SQLITE_DONE结果代码指示操作已完成。SQLITE_DONE结果代码最通常被视为来自sqlite3_step()的返回值,指示SQL语句已运行完毕。但是SQLITE_DONE也可以由其他多步接口(例如sqlite3_backup_step())返回。
所述sqlite3_load_extension()界面载荷的 扩展成一个单一的数据库连接。默认行为是在数据库连接关闭时自动卸载该扩展名。但是,如果扩展入口点返回SQLITE_OK_LOAD_PERMANENTLY而不是SQLITE_OK,则在数据库连接关闭后,扩展将仍然加载到进程地址空间中。换句话说,当数据库连接关闭时,不会为扩展调用sqlite3_vfs对象的xDlClose方法。
例如,SQLITE_OK_LOAD_PERMANENTLY返回码对于注册新VFS的可加载扩展很有用 。
SQLITE_ERROR_MISSING_COLLSEQ结果代码表示无法准备一条SQL语句,因为找不到该SQL语句中命名的排序顺序。
有时,遇到此错误代码时, sqlite3_prepare_v2()例程会将错误转换为 SQLITE_ERROR_RETRY,然后再次尝试使用不需要使用未知整理序列的其他查询计划来准备SQL语句。
该SQLITE_BUSY_RECOVERY错误代码是一个扩展错误代码 为SQLITE_BUSY指示的操作无法继续,因为另一个进程正忙于回收WAL模式的数据库文件崩溃之后。SQLITE_BUSY_RECOVERY错误代码仅在WAL模式数据库上发生。
SQLITE_LOCKED_SHAREDCACHE结果代码指示在共享缓存模式下,使用同一记录的另一个数据库连接阻止了对SQLite数据记录的访问。当两个或多个数据库连接共享相同的缓存,并且其中一个连接处于修改该缓存中的记录的中间时,则在进行修改时,其他连接将被阻止访问该数据,以防止读取器看到已损坏或部分完成的更改。
所述SQLITE_READONLY_RECOVERY错误代码是一个扩展的错误代码 为SQLITE_READONLY。SQLITE_READONLY_RECOVERY错误代码指示无法打开WAL模式数据库,因为需要恢复数据库文件,并且恢复需要写访问权限,但只有读访问权限可用。
所述SQLITE_IOERR_READ错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在一个I / O错误VFS层,而试图从磁盘上的文件中读取。此错误可能是由硬件故障引起的,也可能是由于在打开文件时卸载了文件系统。
所述SQLITE_CORRUPT_VTAB错误代码是一个扩展的错误代码 为SQLITE_CORRUPT通过使用虚拟表。一个虚拟表可能会返回SQLITE_CORRUPT_VTAB以指示虚表的内容已损坏。
不再使用SQLITE_CANTOPEN_NOTEMPDIR错误代码。
所述SQLITE_CONSTRAINT_CHECK错误代码是一个扩展的错误代码 为SQLITE_CONSTRAINT指示CHECK约束失败。
恢复WAL模式数据库文件时 ,SQLITE_NOTICE_RECOVER_WAL结果代码将传递到sqlite3_log()的回调 。
每当使用自动索引时 ,SQLITE_WARNING_AUTOINDEX结果代码将传递到sqlite3_log()的回调 。这可以向应用程序设计者发出警告,即数据库可能会从附加索引中受益。
SQLITE_ERROR_RETRY在内部用于引发sqlite3_prepare_v2() (或其用于创建准备好的语句的同级例程之一),以再次尝试准备失败的语句,该语句在上一次尝试中出错。
SQLITE_ABORT_ROLLBACK错误代码是SQLITE_ABORT的扩展错误代码 ,指示SQL语句异常终止,因为该SQL语句首次启动时处于活动状态的事务已回滚。回滚发生时,挂起的写操作始终会因此错误而失败。一个ROLLBACK会导致如果模式是内正在推出交易回改变挂起的读操作只有失败。
所述SQLITE_BUSY_SNAPSHOT错误代码是一个扩展的错误代码 为SQLITE_BUSY发生上WAL模式数据库,当数据库的连接尝试,以促进读事务成写事务但发现另一个数据库连接已经写入数据库并因此无效之前读取。
以下方案说明了如何发生SQLITE_BUSY_SNAPSHOT错误:
SQLite核心不使用SQLITE_LOCKED_VTAB结果代码,但扩展程序可以使用它。虚拟表实现可以返回此结果代码以指示由于其他线程或进程持有的锁,它们无法完成当前操作。
当另一个准备好的语句正在主动读取R-Tree时,尝试更新R-Tree时 ,R-Tree扩展将返回此结果代码。更新无法继续进行,因为对R-Tree的任何更改都可能涉及节点的重新组合和重新平衡,这将破坏读取游标,从而导致某些行被重复,而另一些行将被省略。
所述SQLITE_READONLY_CANTLOCK错误代码是一个扩展的错误代码 为SQLITE_READONLY。SQLITE_READONLY_CANTLOCK错误代码指示SQLite无法获得WAL模式数据库上的读取锁,因为与该数据库关联的共享内存文件是只读的。
所述SQLITE_IOERR_SHORT_READ错误代码是一个扩展的错误代码 为SQLITE_IOERR表明在读取尝试VFS层无法为被请求以获得尽可能多的字节。这可能是由于文件被截断了。
SQLITE_CORRUPT_SEQUENCE结果代码表示sqlite_sequence表的架构已损坏。sqlite_sequence表用于帮助实现AUTOINCREMENT功能。sqlite_sequence表应具有以下格式:
创建表sqlite_sequence(name,seq);
如果SQLite发现sqlite_sequence表具有任何其他格式,它将返回SQLITE_CORRUPT_SEQUENCE错误。
该SQLITE_CANTOPEN_ISDIR错误代码是一个扩展错误代码 为SQLITE_CANTOPEN表示文件打开操作失败,因为该文件实际上是目录。
所述SQLITE_CONSTRAINT_COMMITHOOK错误代码是一个扩展的错误代码 为SQLITE_CONSTRAINT指示 commit钩子回调返回非零,如此造成被回滚的SQL语句。
当热日志回滚时 ,SQLITE_NOTICE_RECOVER_ROLLBACK结果代码将传递到sqlite3_log()的回调 。
当尝试通过使用sqlite3_snapshot_open()接口在数据库的历史版本上启动读取事务时,可能返回SQLITE_ERROR_SNAPSHOT结果代码。如果历史快照不再可用,则读取事务将失败,并显示SQLITE_ERROR_SNAPSHOT。仅当使用-DSQLITE_ENABLE_SNAPSHOT编译SQLite时,才可能出现此错误代码。
SQLITE_BUSY_TIMEOUT错误代码指示由于超时,VFS层中的阻塞Posix咨询文件锁定请求失败。阻止Posix咨询锁仅作为专有的SQLite扩展提供,并且即使使用SQLITE_EANBLE_SETLK_TIMEOUT编译时选项编译SQLite时,才支持。
所述SQLITE_READONLY_ROLLBACK错误代码是一个扩展的错误代码 为SQLITE_READONLY。SQLITE_READONLY_ROLLBACK错误代码指示无法打开数据库,因为该数据库具有需要回滚的热日志,但由于数据库为只读而无法打开。
所述SQLITE_IOERR_WRITE错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在一个I / O错误VFS层而试图写入到磁盘上的文件。此错误可能是由硬件故障引起的,也可能是由于在打开文件时卸载了文件系统。如果文件系统已满,则不应发生此错误,因为有单独的错误代码(SQLITE_FULL)用于此目的。
SQLITE_CORRUPT_INDEX结果代码意味着SQLite检测到索引中存在或缺少条目。这是SQLITE_CORRUPT错误代码的特殊情况,它表示通过假定数据库文件中其他位置不存在其他问题,可以通过运行REINDEX命令来解决该问题。
该SQLITE_CANTOPEN_FULLPATH错误代码是一个扩展错误代码 为SQLITE_CANTOPEN表示文件打开操作失败,因为操作系统无法将文件名转换成一个完整的路径名。
该SQLITE_CONSTRAINT_FOREIGNKEY错误代码是一个扩展错误代码 为SQLITE_CONSTRAINT指示外键约束失败。
所述SQLITE_READONLY_DBMOVED错误代码是一个扩展的错误代码 为SQLITE_READONLY。SQLITE_READONLY_DBMOVED错误代码指示由于自打开数据库文件以来已移动数据库文件,因此无法修改数据库,因此,如果由于未正确命名回滚日志而导致进程崩溃,则任何修改数据库的尝试都可能导致数据库损坏 。
所述SQLITE_IOERR_FSYNC错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在一个I / O错误VFS层而试图刷新先前写入的内容进行OS和/或磁盘的控制缓冲器,并进入持久存储。换句话说,此代码指示UNIX中的fsync()系统调用或Windows中的FlushFileBuffers()系统调用存在问题。
该SQLITE_CANTOPEN_CONVPATH错误代码是一个扩展错误代码 为SQLITE_CANTOPEN只由Cygwin的VFS和指示cygwin_conv_path()系统调用,而试图打开一个文件失败。另请参阅:SQLITE_IOERR_CONVPATH
SQLite内核当前未使用SQLITE_CONSTRAINT_FUNCTION错误代码。但是,此错误代码可供扩展功能使用。
SQLITE_READONLY_CANTINIT结果代码起源于VFS的xShmMap方法,以指示 存在WAL模式使用的共享内存区域,但是其内容对于当前进程而言是不可靠且无法使用的,因为当前进程对共享内存区域没有写权限。(用于WAL模式的共享内存区域通常是带有“ -wal”后缀的文件,该文件被映射到进程空间中。如果当前进程对该文件没有写权限,则它将无法写入共享内存。)
SQLite中的高层逻辑通常会拦截错误代码并创建一个临时的内存共享内存区域,以便当前进程至少可以读取数据库的内容。此结果代码不应到达应用程序接口层。
所述SQLITE_IOERR_DIR_FSYNC错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在一个I / O错误VFS层,而上的目录试图调用FSYNC()。在创建或删除某些文件后,Unix VFS会尝试对目录进行fsync(),以确保在断电或系统崩溃后,这些文件仍会出现在文件系统中。该错误代码表示尝试执行该fsync()时出现问题。
目前不使用SQLITE_CANTOPEN_DIRTYWAL结果代码。
该SQLITE_CONSTRAINT_NOTNULL错误代码是一个扩展错误代码 为SQLITE_CONSTRAINT指示NOT NULL约束失败。
SQLITE_READONLY_DIRECTORY结果代码指示数据库是只读的,因为进程无权在与数据库相同的目录中创建日志文件,并且创建日志文件是写入的前提条件。
所述SQLITE_IOERR_TRUNCATE错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在一个I / O错误VFS层在尝试将文件截断到较小尺寸。
当使用SQLITE_OPEN_NOFOLLOW标志并且数据库文件是符号链接时 ,sqlite3_open()接口及其同级 返回SQLITE_CANTOPEN_SYMLINK结果代码 。
所述SQLITE_CONSTRAINT_PRIMARYKEY错误代码是一个扩展的错误代码 为SQLITE_CONSTRAINT指示PRIMARY KEY约束失败。
所述SQLITE_IOERR_FSTAT错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在一个I / O错误VFS层,同时为了确定的信息上的文件试图调用FSTAT()(或等价物),诸如文件大小或访问权限。
该SQLITE_CONSTRAINT_TRIGGER错误代码是一个扩展错误代码 为SQLITE_CONSTRAINT指示RAISE功能一个内触发开枪,导致SQL语句中止。
所述SQLITE_IOERR_UNLOCK错误代码是一个扩展的错误代码 为SQLITE_IOERR指示上xUnlock方法内的I / O错误sqlite3_io_methods对象。
所述SQLITE_CONSTRAINT_UNIQUE错误代码是一个扩展的错误代码 为SQLITE_CONSTRAINT指示UNIQUE约束失败。
所述SQLITE_IOERR_UNLOCK错误代码是一个扩展的错误代码 为SQLITE_IOERR指示XLOCK方法内的I / O错误在sqlite3_io_methods而试图得到一个读锁定对象。
SQLite内核当前未使用SQLITE_CONSTRAINT_VTAB错误代码。但是,此错误代码可供应用程序定义的虚拟表使用。
所述SQLITE_IOERR_UNLOCK错误代码是一个扩展的错误代码 为SQLITE_IOERR指示上xDelete方法内的I / O错误sqlite3_vfs对象。
所述SQLITE_CONSTRAINT_ROWID错误代码是一个扩展的错误代码 为SQLITE_CONSTRAINT指示ROWID不是唯一的。
该SQLITE_CONSTRAINT_PINNED错误代码是一个扩展错误代码 为SQLITE_CONSTRAINT表明一个UPDATE触发器试图做删除正在中间的更新更新的行。
VFS 层 有时会返回SQLITE_IOERR_NOMEM错误代码,以指示由于无法分配足够的内存而无法完成操作。该错误代码通常在返回到应用程序之前由更高级别的SQLite转换为SQLITE_NOMEM。
所述SQLITE_IOERR_ACCESS错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在Xaccess文件方法内的I / O错误sqlite3_vfs对象。
所述SQLITE_IOERR_CHECKRESERVEDLOCK错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在xCheckReservedLock方法内的I / O错误sqlite3_io_methods对象。
所述SQLITE_IOERR_LOCK错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在咨询文件锁定逻辑的I / O错误。通常,SQLITE_IOERR_LOCK错误指示获取PENDING锁时出现问题。但是,它也可能表示在Mac上使用的某些专用VFS上的其他锁定错误。
所述SQLITE_IOERR_ACCESS错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在xClose方法内的I / O错误sqlite3_io_methods对象。
不再使用SQLITE_IOERR_DIR_CLOSE错误代码。
所述SQLITE_IOERR_SHMOPEN错误代码是一个扩展的错误代码 为SQLITE_IOERR指示xShmMap方法在内的I / O错误sqlite3_io_methods在尝试打开新的共享存储器段对象。
所述SQLITE_IOERR_SHMSIZE错误代码是一个扩展的错误代码 为SQLITE_IOERR指示xShmMap方法在内的I / O错误sqlite3_io_methods而试图放大一个对象“SHM”文件作为其一部分 WAL模式事务处理。该错误可能表明基础文件系统卷空间不足。
所述SQLITE_IOERR_SHMMAP错误代码是一个扩展的错误代码 为SQLITE_IOERR指示xShmMap方法在内的I / O错误sqlite3_io_methods而试图映射的共享存储器段到进程地址空间物体。
所述SQLITE_IOERR_SEEK错误代码是一个扩展的错误代码 为SQLITE_IOERR指示所述的xRead或xWrite方法内的I / O错误sqlite3_io_methods而试图寻求一个文件描述符到所读出或写入是发生在文件的开头点对象。
所述SQLITE_IOERR_DELETE_NOENT错误代码是一个扩展的错误代码 为SQLITE_IOERR指示在所述xDelete方法sqlite3_vfs对象失败因为要删除的文件不存在。
所述SQLITE_IOERR_MMAP错误代码是一个扩展的错误代码 用于SQLITE_IOERR指示一个I / O错误内对所述xFetch或xUnfetch方法sqlite3_io_methods而试图映射或数据库文件到进程的地址空间的一部分去映射对象。
所述SQLITE_IOERR_GETTEMPPATH错误代码是一个扩展的错误代码 为SQLITE_IOERR指示VFS是无法确定在其中放置临时文件合适的目录。
所述SQLITE_IOERR_CONVPATH错误代码是一个扩展的错误代码 为SQLITE_IOERR使用仅由Cygwin的VFS和指示cygwin_conv_path()系统调用失败。另请参阅:SQLITE_CANTOPEN_CONVPATH
SQLITE_IOERR_VNODE错误代码是保留供扩展使用的代码。SQLite核心不使用它。
SQLITE_IOERR_AUTH错误代码是保留供扩展使用的代码。SQLite核心不使用它。
SQLITE_IOERR_BEGIN_ATOMIC错误代码指示底层操作系统已报告并且SQLITE_FCNTL_BEGIN_ATOMIC_WRITE文件控件上存在错误 。仅当启用SQLITE_ENABLE_ATOMIC_WRITE且数据库托管在支持原子写入的文件系统上时,才会出现此消息。
SQLITE_IOERR_COMMIT_ATOMIC错误代码指示底层操作系统已报告并且SQLITE_FCNTL_COMMIT_ATOMIC_WRITE文件控件上存在错误 。仅当启用SQLITE_ENABLE_ATOMIC_WRITE且数据库托管在支持原子写入的文件系统上时,才会出现此消息。
SQLITE_IOERR_ROLLBACK_ATOMIC错误代码指示基础操作系统已报告并且SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE文件控件上存在错误 。仅当启用SQLITE_ENABLE_ATOMIC_WRITE且数据库托管在支持原子写入的文件系统上时,才会出现此消息。
该SQLITE_IOERR_DATA错误代码是一个扩展错误代码 为SQLITE_IOERR仅用于校验和VFS垫片,以表明该数据库文件的页上的校验和不正确。