bitsCN.com
开发人员写了一个view,select要30分钟,让我优化下,view如下:
开发人员select一下需要30多分钟:
21068 rows in set (1987.08 sec)
先解析一下:
mysql> explain SELECT `ol`.`OFFER_ID` AS `OFFER_ID`,`ol`.`EFFECTIVE_DATE` AS `EFFECTIVE_DATE`
看到有 Using filesort,要优化where后面的子判断,优化如下:
select max(ol2.ID)
有些不对劲,再仔细看了view的结构,恍然大悟:
优化成如下样子:
CREATE ALGORITHM=UNDEFINED SQL SECURITY DEFINER VIEW view_offer_label AS
执行结果为:
21068 rows in set (0.08 sec)
不到0.08秒,数据完全正确。
bitsCN.com
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号