小编Lun*_*Thi的帖子

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

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

cur.executemany("INSERT INTO " + tableName + " VALUES (?, ?, ?, ?);", data)
Run Code Online (Sandbox Code Playgroud)

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

我尝试了不同的代码变体.我的最新代码是从前一个关于更新和执行的问题的答案,但它对我来说和我做的任何其他尝试一样慢:

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()
Run Code Online (Sandbox Code Playgroud)

如何有效地改进此代码以进行大量更新?

python sqlite python-2.7 bulkupdate

5
推荐指数
1
解决办法
1042
查看次数

标签 统计

bulkupdate ×1

python ×1

python-2.7 ×1

sqlite ×1