MySQL优化技术系列-谓词下推(pushdown)
谓词下推
将外层查询块的 WHERE 子句中的谓词移入所包含的较低层查询块(例如视图),从而能够提早进行数据过滤以及有可能更好地利用索引。
这在分区数据库环境中甚至更为重要,其原因在于,提早进行过滤有可能减少必须在数据库分区之间传递的数据量。此优化技术在 SQL 中被称为谓词下推(Predicate pushdown) 。
基本策略
基本策略是,始终将过滤表达式尽可能移至靠近数据源的位置。
事实主流的数据库基本上都支持这种方式的优化。其原则是在一个查询树中,对于任何选择都尽量早做选择,然后进行一步的处理.
可见我们并不需要改写这个sql,优化器会自动去帮我们做这种优化。
最佳实践
验证方法:可以使用explain analyze查看下面两个SQL的执行计划,发现几乎是一样的。
优化前的SQL:
SELECT * FROM t_student, t_score WHERE t_score.student_id=t_student.student_id AND t_score.score_id<1002;
谓词下推优化:
SELECT * FROM t_student t1
right JOIN (SELECT * from t_score WHERE score_id<1002) t2
ON t1.student_id=t2.student_id;
本文来自博客园,作者:业余砖家,转载请注明原文链接:https://www.cnblogs.com/yeyuzhuanjia/p/16581264.html

浙公网安备 33010602011771号