与直接查询相比,对特定状态下的用户进行计数的查询显示视图的成本更高表扫描。 WHERE 子句在视图中如何工作,如何解决这个性能问题?
视图中 WHERE 子句的行为由所使用的视图算法决定。
通常,在视图中,在视图从基础表中检索所有行之后应用 WHERE 子句。该算法被称为temptable。然而,在这种情况下,没有使用temptable算法。相反,采用了 merge 算法。
合并算法在大多数情况下更有效,但当视图包含聚合函数(如 COUNT())或 GROUP BY 子句时,不支持该算法.要解决此问题,可以修改视图定义,将 COUNT(*) 替换为 COUNT(DISTINCT state)。这将强制MySQL使用合并算法,这可以显着提高性能。以上是当 WHERE 子句影响计数查询时如何优化视图性能?的详细内容。更多信息请关注PHP中文网其他相关文章!