SQLite Upsert:镜像 MySQL 的 ON DUPLICATE KEY UPDATE 功能
MySQL 的 ON DUPLICATE KEY UPDATE
简化了基于唯一键约束的插入或更新行。 如果键唯一,则此单个查询插入新行;如果发现重复键,则更新现有行。 SQLite 缺乏这种直接的等价物。
SQLite 中更新插入的解决方法
SQLite 提供了替代策略来实现相同的结果:
1。 选择然后插入或更新:
此方法使用两个查询:
SELECT
查询,用于检查是否存在具有给定键的行。INSERT
或 UPDATE
查询,具体取决于 SELECT
查询的结果。此方法需要两次数据库交互,可能会影响性能。
2。 失败时更新,然后插入:
这涉及带有错误处理的单个 UPDATE
查询:
UPDATE
表示现有行,并且数据已更新。UPDATE
(由于行不存在)会触发INSERT
查询。虽然这将数据库调用减少到一次,但需要对失败的 INSERT
尝试进行额外的错误处理(例如,由于重复的键)。
最佳 SQLite 更新插入策略
最高效、最强大的 SQLite upsert 方法结合了 INSERT OR IGNORE
和 UPDATE
:
<code class="language-sql">INSERT OR IGNORE INTO visits VALUES ($ip, 0); UPDATE visits SET hits = hits + 1 WHERE ip LIKE $ip;</code>
这需要对“ip”列进行 UNIQUE
或 PRIMARY KEY
约束。 INSERT OR IGNORE
尝试插入;如果存在重复的键,它将被默默地忽略。 随后的 UPDATE
然后会增加现有行的命中计数器。 该解决方案既提高了效率(单个数据库往返),又避免了重复键插入造成的错误。
以上是如何在SQLite中实现MySQL的ON DUPLICATE KEY UPDATE功能?的详细内容。更多信息请关注PHP中文网其他相关文章!