ON CONFLICT语句

这是一个非标准的SQL扩展,只能用在SQLite中。自3.0.0版本增加。该语句也是UPSERT语句的一部分。UPSERT是3.24.0版本增加的、对INSERT语句的非标准扩展。

ON CONFLICT直接用于CREATE TABLE命令,而在UPDATE、INSERT命令中使用OR替代了ON CONFLICT,这样更易于阅读。比如INSERT ON CONFLICT IGNORE实际应为INSERT OR IGNORE

ON CONFLICT子句适用于UNIQUE、NOT NULL、CHECK和PRIMARY KEY约束,但不适用FOREIGN KEY约束。 有5个冲突解决方法:ROLLBACK, ABORT, FAIL, IGNORE和REPLACE,默认是ABORT。

  • ROLLBACK

    当发生适用的约束冲突时,该方法回滚当前事务、撤销当前语句并报告一个SQLITE_CONSTRAINT错误。如果当前没有活动的事务(除去每条查询隐式创建的事务),该方法和ABORT没有区别。

  • ABORT

    当发生适用的约束冲突时,该方法撤销当前语句并报告一个SQLITE_CONSTRAINT错误,同时取消当前查询语句所做的修改,事务内之前的更新操作不受影响。

  • FAIL

    当发生适用的约束冲突时,该方法撤销当前语句并报告一个SQLITE_CONSTRAINT错误,但是该语句之前做的修改不会撤销,也不会结束事务。比如一条更新语句在更新到第100条时发生了约束冲突,之前更新的99条数据保留更新,而在100条以及之后不会再处理。

    FAIL行为仅对唯一性、NOT NULL和CHECK约束有效。外键约束冲突会触发ABORT。

  • IGNORE

    当发生适用的约束冲突时,该方法忽略冲突的行并继续处理后面的数据。对于唯一性、NOT NULL和CHECK约束冲突不会报错,但对外键约束冲突的表现和ABORT一致。

  • REPLACE

    当一个UNIQUE或PRIMARY KEY约束冲突发生时,该方法在插入与更新当前行之前删除导致约束冲突的行,然后继续执行命令。如果发生了NOT NULL约束冲突,该方法则是使用列的默认值代替NULL值。如果列未指定默认值则行为和ABORT一致。如果发生CHECK约束或外键约束冲突,该方法的行为和ABORT一致。

    如果开启了recursive triggers,该方法在删除导致约束冲突的行时会启动delete triggers触发器。那些被删除的行不会回传给update hook指定的回调函数,也不会增加change counter计数。(C语言接口sqlite3_changessqlite3_changes64的返回值)

相关推荐
CC城子2 分钟前
EtherCAT研究之物理层PHY(一)
linux·运维·数据库
yyuuuzz5 分钟前
国际云服务器的技术特点与使用经验
运维·服务器·网络·数据库·云计算·aws
TDengine (老段)6 分钟前
TDengine VNode 生命周期 — 从创建到销毁的完整旅程
大数据·数据库·重构·系统架构·负载均衡·tdengine·涛思数据
2301_783848657 分钟前
JavaScript中利用Symbol实现单例模式的属性锁定
jvm·数据库·python
Elastic 中国社区官方博客12 分钟前
在 Kubernetes 上的 Elastic Cloud:简化的可用区感知、重启和 mTLS
大数据·数据库·搜索引擎·云原生·容器·kubernetes·全文检索
努力努力再努力wz16 分钟前
【Redis入门系列】Redis基础命令详解:从客户端连接到数据读写、key 管理与过期机制
c语言·开发语言·数据结构·数据库·c++·redis·缓存
m0_6091604916 分钟前
如何使用Python查询MongoDB并转为Pandas DataFrame_数据分析集成实战
jvm·数据库·python
环流_18 分钟前
分清redis主要数据操作中的key
数据库·redis·哈希算法
西京刀客23 分钟前
redis 大key使用 UNLINK 命令删除、Redis Set / ZSet 存储上限、ZRemRangeByRank命令
数据库·redis·缓存
woxihuan12345627 分钟前
c++怎么利用std--variant处理多种二进制子协议包的自动分支解析【进阶】
jvm·数据库·python