mysql分组查询性能优化_MySQL分组查询优化

我有三个表:类别,文章和article_events,具有以下结构

categories: id, name (100,000 rows)

articles: id, category_id (6000 rows)

article_events: id, article_id, status_id (20,000 rows)

每篇文章行的最高article_events.id描述了每篇文章的当前状态.

我正在返回一个类别表,其中包含最近事件status_id为“1”的文章数量.

到目前为止我的工作,但是我的桌子大小相当慢(10秒).想知道是否有办法让这更快.据我所知,所有表都有适当的索引.

SELECT c.id,

c.name,

SUM(CASE WHEN e.status_id = 1 THEN 1 ELSE 0 END) article_count

FROM categories c

LEFT JOIN articles a ON a.category_id = c.id

LEFT JOIN (

SELECT article_id, MAX(id) event_id

FROM article_events

GROUP BY article_id

) most_recent ON most_recent.article_id = a.id

LEFT JOIN article_events e ON most_recent.event_id = e.id

GROUP BY c.id

基本上我必须两次加入事件表,因为要求status_id和MAX(id)只返回它找到的第一个status_id,而不是与MAX(id)行相关的那个.

有什么办法让这更好吗?或者我只需要活10秒钟?谢谢!

编辑:

这是我的EXPLAIN查询:

ID | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra

---------------------------------------------------------------------------------------------------------------------------

1 | PRIMARY | c | index | NULL | PRIMARY | 4 | NULL | 124044 | Using index; Using temporary; Using filesort

1 | PRIMARY | a | ref | category_id | category_id | 4 | c.id | 3 |

1 | PRIMARY | | ALL | NULL | NULL | NULL | NULL | 6351 |

1 | PRIMARY | e | eq_ref | PRIMARY | PRIMARY | 4 | most_recent.event_id | 1 |

2 | DERIVED | article_events | ALL | NULL | NULL | NULL | NULL | 19743 | Using temporary; Using filesort

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值