mysql分组查询的依据,MySQL更新查询,左连接和分组依据

MySQL更新查询,左连接和分组依据

我正在尝试创build更新查询,并在获取正确的语法方面取得一点进展。 以下查询正在工作:

SELECT t.Index1, t.Index2, COUNT( m.EventType ) FROM Table t LEFT JOIN MEvents m ON (m.Index1 = t.Index1 AND m.Index2 = t.Index2 AND (m.EventType = 'A' OR m.EventType = 'B') ) WHERE (t.SpecialEventCount IS NULL) GROUP BY t.Index1, t.Index2

它创build一个三元组Index1,Index2,EventCounts的列表。 它仅在t.SpecialEventCount为NULL的情况下执行此操作。 我正在尝试编写的更新查询应将此SpecialEventCount设置为该计数,即上述查询中的COUNT(m.EventType)。 这个数字可能是0或任何正数(因此左连接)。 索引1和索引2在表t中是唯一的,它们用于识别MEvent中的事件。

我如何修改select查询成为更新查询? 也就是说

UPDATE Table SET SpecialEventCount=COUNT(m.EventType).....

但我很困惑把什么放在哪里,失败了许多不同的猜测。

我认为(Index1, Index2)是Table上的唯一键,否则我会期望引用t.SpecialEventCount导致错误。

编辑查询使用子查询,因为它不能使用GROUP BY

UPDATE Table AS t LEFT JOIN ( SELECT Index1, Index2, COUNT(EventType) AS NumEvents FROM MEvents WHERE EventType = 'A' OR EventType = 'B' GROUP BY Index1, Index2 ) AS m ON m.Index1 = t.Index1 AND m.Index2 = t.Index2 SET t.SpecialEventCount = m.NumEvents WHERE t.SpecialEventCount IS NULL

使用子查询执行左连接将生成一个巨大的临时表,其内存不会有索引。

对于更新,请尝试避免连接并使用相关的子查询:

UPDATE Table AS t SET t.SpecialEventCount = ( SELECT COUNT(m.EventType) FROM MEvents m WHERE m.EventType in ('A','B') AND m.Index1 = t.Index1 AND m.Index2 = t.Index2 ) WHERE t.SpecialEventCount IS NULL

做一些分析,但在某些情况下,这可能会快得多。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值