当前位置: 首页 > article >正文

EXIST与JOIN连表比较

结论

1:EXIST可以用于链表,且可以利用到索引2:当join无法合理利用到索引,可以尝试EXIST链表3:EXIST在某些情况下可以更好地利用到索引4:大数据量时,要考虑EXIST的使用

EXIST  SQL:

EXPLAN

JOIN SQL:

EXPLAN

GPT解释的原因

EXISTS 子查询
在第一个查询中使用了EXISTS子查询,这种结构通常被优化为半连接(semi-join),其目的是检查子查询的结果是否存在,而不是真正地进行两表之间的完整连接。当MySQL优化器处理带有EXISTS的查询时,它可能会选择一种更高效的路径来查找匹配的数据行,特别是在外部查询和子查询之间存在合适的索引时。在这个例子中,由于gm.mark_type上有索引,MySQL可以高效地检查goods_mark_type_common表中的mark_type值是否满足条件,并且快速确定是否存在匹配项,从而能够有效地利用索引。JOIN 操作
第二个查询使用了JOIN操作结合DISTINCT来消除重复的记录。尽管g.mark_type = gm.mark_type条件理论上允许MySQL利用gm.mark_type上的索引来加速连接过程,但实际能否有效利用索引还受到多个因素的影响,比如数据分布、连接类型的选择、以及MySQL版本等。此外,使用DISTINCT可能需要额外的操作来确保结果集的唯一性,这可能会导致MySQL无法仅依赖索引完成整个查询过程,特别是如果MySQL认为先执行连接再过滤和去重比直接利用索引更加高效的话。然而,值得注意的是,现代版本的MySQL在优化JOIN查询方面已经做了很多改进,使得在许多情况下也能很好地利用索引。如果你发现你的JOIN查询没有如预期那样利用索引,可能是由于特定的数据特性或查询条件导致的。可以通过查看具体的EXPLAIN输出了解MySQL是如何执行这些查询的,进而调整查询或者数据库配置以改善性能。

http://www.lryc.cn/news/2383380.html

相关文章:

  • 【Linux】利用多路转接epoll机制、ET模式,基于Reactor设计模式实现
  • 【jvm第7集】jvm调优工具(命令行工具)
  • react中运行 npm run dev 报错,提示vite.config.js出现错误 @esbuild/win32-x64
  • 鸿蒙UI开发——Builder与LocalBuilder对比
  • 关于光谱相机的灵敏度
  • Model 速通系列(一)nanoGPT
  • 微信小程序中,一个页面的数据改变了,怎么通知另一个页面也改变?
  • MySQL--day4--排序与分页
  • 自动化测试脚本点击运行后,打开Chrome很久??
  • iOS热更新技术要点与风险分析
  • 系统架构设计(十二):统一过程模型(RUP)
  • 系分论文《论软件系统安全分析和应用》
  • Mac安装redis
  • srs-7.0 支持obs推webrtc流
  • Babylon.js学习之路《七、用户交互:鼠标点击、拖拽与射线检测》
  • 星际争霸小程序:用Java实现策略模式的星际大战
  • 请问交换机和路由器的区别?vlan 和 VPN 是什么?
  • BERT 作为Transformer的Encoder 为什么采用可学习的位置编码
  • Python数据可视化高级实战之一——绘制GE矩阵图
  • StreamSaver实现大文件下载解决方案
  • 【Vue 3全栈实战】从响应式原理到企业级架构设计
  • Java线程池调优与实践经验
  • 【科研项目】大三保研人科研经历提升
  • 期刊采编系统安装升级错误
  • CSS【详解】弹性布局 flex
  • 自回归图像编辑 EditAR: Unified Conditional Generation with Autoregressive Models
  • React Flow 中 Minimap 与 Controls 组件使用指南:交互式小地图与视口控制定制(含代码示例)
  • 基于YOLOv8 的分类道路目标系统-PyTorch实现
  • STM32之串口通信WIFI上云
  • PCB智能报价系统——————仙盟创梦IDE