CTEs和视图(CTEs and Views):视图作为存储的查询,可以简化应用,也可以实现数据安全,而CTEs与视图类似,只是其生命期仅仅局限于相关查询语句本身。mysql优化器对CTEs和视图的处理,主要有两种策略,那就是合并处理(Merge)和物化处理(Materialize),针对CTEs和视图,mysql优化器首先尝试对其进行与主查询的合并,当某些场景导致其不能与住查询合并时,才会考虑通过将视图或CTEs结果通过临时表进行固化,以供主查询其他部分进行查询使用。这点explain后show warings可以看到这些场景的出现。