首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使10k查询SQL更快

使10k查询SQL更快
EN

Stack Overflow用户
提问于 2020-01-02 15:17:26
回答 2查看 183关注 0票数 0

我试图从Python对mysql服务器执行超过10k的查询,下面是我准备好的查询语句

代码语言:javascript
复制
UPDATE `rates` 
SET `in`=%s, `out`=%s, `amount`=%s, `minamount`=%s, `maxamount`=%s 
WHERE `from`='EXMRUB' AND `to`='YAMRUB' AND `id_site`= 1

问题是它运行得非常慢,我的意思是执行10k更新大约需要5分钟,我如何修改,我的查询使它更快?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-01-02 15:44:23

假设id_site是表的主键,则可以将use a little MySQL trickexecutemany结合起来以加快更新:

代码语言:javascript
复制
INSERT INTO rates (id_site, `in`, `out`, amount, minamount, maxamount)
    VALUES (%s, %s, %s, %s, %s, %s)
ON DUPLICATE KEY UPDATE
    `in`=VALUES(`in`)
,   `out`=VALUES(`out`)
,   amount=VALUES(amount)
,   minamount=VALUES(minamount)
,   maxamount=VALUES(maxamount);

executemany非常重要,因为它确保循环不是在客户端完成的。

票数 1
EN

Stack Overflow用户

发布于 2020-01-02 15:20:09

您可以使用(``from``, ``to``, ``id_site``)上的索引来加速每个单独的查询。

但是,最好将数据加载到数据库中的一个单独的表中,然后使用join在一条语句中进行更新。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59565721

复制
相关文章

相似问题

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