首页 > 解决方案 > 慢更新查询 SQLite

问题描述

使用选择查询从另一个表的数据获取更新参数时,SQLite 更新如此缓慢是否有特殊原因?

例如,如果我这样做:

UPDATE cits SET cit_edu_lvl =  cit_edu_lvl + 1, cit_edu_status = 0, cit_age = 18

它在 < 1 秒内运行

但如果我这样做

UPDATE cits SET cit_edu_lvl = cit_edu_lvl + (
SELECT cit_edu_update_amt FROM education_enrollment ee WHERE ee.cit_ck = 
cits.cit_ck)
WHERE cit_ck in (select cit_ck FROM education_enrollment)

要从其他表中获取相同的数据并使用它进行更新,需要 12 秒。

我错过了什么?我在 SQLiteStudio 中直接运行,所以批处理不是问题。如果我要在我的 c# 应用程序中运行它,我会相应地使用批处理。

谢谢

标签: c#sqlite

解决方案


SQLite 不支持正式的更新连接语法,这可能是您在这里尝试做的第一件事。但是,我们可以尝试向education_enrollment表中添加索引来加速相关子查询:

CREATE INDEX idx ON education_enrollment(cit_ck, cit_edu_update_amt);

请注意,如果 SQLite 不允许您向education_enrollment已存在的表添加索引,则可能必须使用此索引重新创建表。


推荐阅读