首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用join和group优化更新查询

使用join和group优化更新查询
EN

Stack Overflow用户
提问于 2013-01-30 08:55:51
回答 2查看 438关注 0票数 0

我有一个包含字段DATASOURCE、PEOPLEID、TOTVALUE (~6兆记录)的表总计和一个带有字段PEOPLEID和值(ab )的表source1。3百万记录)。在总计中,每个DATASOURCE都有惟一的用户,而在source1中,每个数据源都有几条记录。source1中所有的人都已经被包括在totals中,而不是他们的价值观中。

我成功地获得了更新查询,该查询更新的TOTVALUE字段,将的字段从“测试”小表上的source1中提取出来,但现在我试图让它在它永远运行的真实表上运行.我要重复一遍source2source3等等.

我运行的查询是:

代码语言:javascript
复制
UPDATE  totals t
    INNER JOIN 
    (
        SELECT  peopleid,
                sum(value) AS TotValues
        FROM source1
        GROUP BY peopleid
    ) s
    ON t.peopleid = s.peopleid
SET t.totvalue = s.TotValues
where
t.datasource like 'source1'

您认为有更好的方法来运行和优化这个查询吗?

EN

回答 2

Stack Overflow用户

发布于 2013-01-30 09:02:46

  • 使用=而不是LIKE,因为,我认为,您不是在搜索模式,对吗?
  • 在两个表上的列INDEX上创建PeopleIDtotalssource
  • 如果可能,还在表datasource上添加totals列的索引

询问,

代码语言:javascript
复制
UPDATE  totals t
        INNER JOIN 
        (
            SELECT  peopleid,
                    sum(value) AS TotValues
            FROM    source1
            GROUP   BY peopleid
        ) s
        ON t.peopleid = s.peopleid
SET     t.peopleid = s.peopleid
WHERE   t.datasource = 'source1'
票数 1
EN

Stack Overflow用户

发布于 2013-01-30 09:03:23

试着先加入数据。记住为两个表中的peopleid列创建索引。

代码语言:javascript
复制
UPDATE  totals t
    INNER JOIN 
    (
        select * from (
          SELECT  t.datasource,
                  peopleid,
                  sum(value) AS TotValues
          FROM source1 s INNER JOIN 
               totals t
                      ON t.peopleid = s.peopleid
          GROUP BY t.datasource, t.peopleid
        ) s_aux
    ) s
    ON t.peopleid = s.peopleid and t.datasource = s.datasource
SET t.totvalue = s.TotValues
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14600024

复制
相关文章

相似问题

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