MySQL8.0.18优化器添加AntiJoin反连接优-创新互联

在MySQL 8.0.18版本里,支持对NOT IN/EXISTS子查询语句优化,优化器内部将查询自动重写为AntiJoin反连接查询SQL语句。

创新互联是专业的矿区网站建设公司,矿区接单;提供成都网站设计、做网站,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行矿区网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

通常情况下,我们希望由内到外,先完成内表里的查询结果,然后驱动外查询的表,完成最终查询,但是子查询会先扫描外表中的所有数据,每条数据将会传到内表中与之关联,如果外表很大的话,那么性能上将会很差。

让我们看一个例子

explain select * from t1 where id not in (select id from t2);

MySQL 8.0.18 优化器添加AntiJoin反连接优

优化器在内部,是将not in子查询重写为下面的语句

explain select t1.* from t1 left join t2 on t1.id=t2.id where t2.id is null;

MySQL 8.0.18 优化器添加AntiJoin反连接优

对比两个执行计划,结果是一样的。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文名称:MySQL8.0.18优化器添加AntiJoin反连接优-创新互联
网址分享:http://pwwzsj.com/article/dooecj.html