博客
关于我
MySQL 8 Anti-Join 几点总结
阅读量:102 次
发布时间:2019-02-26

本文共 1101 字,大约阅读时间需要 3 分钟。

MySQL NOT EXISTS与NOT IN子句的优化与反join新特性

作者:郑松华,知数堂SQL优化班老师,网名:骑龟的兔子

导读

作者郑松华在关注您就感到紧张吗?别担心,今天我就来和大家分享一个MySQL 8.0.18版本中引入的全新特性——反join(Anti Join)。这对数据库性能优化来说是个重大的突破,特别是在处理NOT EXISTS和NOT IN子句时。


MySQL 8.0.18版本中的反join

在5.7版本中,NOT EXISTS和NOT IN子句的执行计划主要依赖DEPENDENT SUBQUERY,这类似于函数调用,需要外层查询为每个结果集进行处理,效率较低。而在8.0.18版本中,这两种子句被优化为反join,这带来了更高效的执行方式。


反join的优势

反join(Anti Join)与传统的DEPENDENT SUBQUERY不同,它不仅支持嵌套循环join,还可以通过哈希join(Hash Join)实现更高效的查询处理。这种机制使得反join在处理大规模数据时效率显著提升。


5.7版本与8.0.18版本的对比

在5.7版本中,执行计划为DEPENDENT SUBQUERY,类似于函数调用,效率较低。而在8.0.18版本中,执行计划变为反join,具体表现为:

  • 5.7版本:执行计划为DEPENDENT SUBQUERY,效率较低。
  • 8.0.18版本:执行计划为反join,可以选择哈希join或嵌套循环join,效率提升。

哈希join的应用场景

哈希join在数据分布较均匀时表现尤为出色。与传统的嵌套循环join相比,哈希join的加速效果更为显著,尤其是在处理大规模数据时,能够更快地找到匹配的记录。


执行计划解读

通过EXPLAIN分析,我们可以更清晰地了解反join的执行方式:

  • 5.7版本:执行计划为DEPENDENT SUBQUERY,效率较低。
  • 8.0.18版本:执行计划为反join,具体为嵌套循环join或哈希join,效率显著提升。

反join的潜在问题

在使用反join时,需要注意以下几点:

  • 索引优化:确保外层表和内层表的索引结构合理,避免过多索引导致执行时间过长。
  • 数据分布:反join的效率依赖于数据分布,建议在数据分布较均匀的场景下使用哈希join。

  • 结论

    反join的引入为MySQL 8.0.18版本带来了全新的查询优化方式,特别是在处理NOT EXISTS和NOT IN子句时。通过反join,我们可以更高效地处理大规模数据,减少执行时间。


    欢迎加入高性能MySQL技术专家群,和我一起探讨更多数据库优化技巧!

    转载地址:http://vnkz.baihongyu.com/

    你可能感兴趣的文章
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
    查看>>
    Node.js的循环与异步问题
    查看>>
    nodejs libararies
    查看>>
    nodejs-mime类型
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    Node入门之创建第一个HelloNode
    查看>>
    NOIp2005 过河
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm和yarn的使用对比
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>