首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何优化mysql中的group_concat子查询?

如何优化mysql中的group_concat子查询?
EN

Stack Overflow用户
提问于 2017-12-07 03:52:49
回答 1查看 104关注 0票数 0

如何优化此查询?执行起来需要很长时间。

代码语言:javascript
复制
SELECT GROUP_CONCAT(`details_value`), details_key  
  FROM `correspondence_package_details` 
 WHERE `correspondence_id` IN (SELECT GROUP_CONCAT(`correspondence_id`) 
                                 FROM `correspondence_package_header` 
                                WHERE create_date BETWEEN '2017-11-01' AND '2017-11-30' 
                               GROUP BY `manual_package_id`,account_id) 
   AND (`details_key` = 'to' OR `details_key` = 'cc') 
 GROUP BY details_key;
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-12-07 04:17:15

查询优化是一门艺术,也是一门科学。通过简单地查看sql,您将限制您的选项。

  1. 对查询运行解释计划。检查低性能连接类型和扫描。
  2. 在所有联接列上添加适当的索引。
  3. 对于日期字段,根据通常是查询最近记录还是最旧记录对索引进行排序。
  4. 定期在数据库上运行优化命令,以便索引和表空间得到快速调整。

查询计划将是这方面的最佳工具。

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

https://stackoverflow.com/questions/47687317

复制
相关文章

相似问题

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