首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Sqlite3 Python:如何进行有效的批量更新?

Sqlite3 Python:如何进行有效的批量更新?
EN

Stack Overflow用户
提问于 2016-04-22 10:10:44
回答 1查看 2K关注 0票数 6

我可以用下面的代码在Python (2.7)的Sqlite3中进行非常高效的批量插入:

代码语言:javascript
运行
复制
cur.executemany("INSERT INTO " + tableName + " VALUES (?, ?, ?, ?);", data)

但是我不能让更新有效地工作。我认为这可能是数据库结构/索引的问题,但即使在只有一个100行的表的测试数据库上,更新仍然需要大约2-3秒。

我尝试过不同的代码变体。我最新的代码来自this answer,回答了之前关于更新和执行的问题,但它对我来说就像我做过的任何其他尝试一样慢:

代码语言:javascript
运行
复制
data = []
for s in sources:
    source_id = s['source_id']
    val = get_value(s['source_attr'])
    x=[val, source_id]
    data.append(x)
cur.executemany("UPDATE sources SET source_attr = ? WHERE source_id = ?", data)
con.commit()

我如何改进这段代码才能高效地进行大批量更新?

EN

回答 1

Stack Overflow用户

发布于 2016-04-22 16:01:51

当插入一条记录时,数据库只需要在表的末尾写一行(除非您有像UNIQUE约束这样的东西)。

更新记录时,数据库需要查找行。这需要扫描整个表(对于每个命令),除非您在搜索列上有索引:

代码语言:javascript
运行
复制
CREATE INDEX whatever ON sources(source_id);

但是如果source_idprimary key,那么您应该这样声明它(这会创建一个隐式索引):

代码语言:javascript
运行
复制
CREATE TABLE sources(
    source_id INTEGER PRIMARY KEY,
    source_attr TEXT,
    [...]
);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36783579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档