爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
MySQL教程
mysql联接优化器是怎么优化join顺序的
mysql联接优化器是怎么优化join顺序的
日期:2014-05-16 浏览次数:20705 次
mysql联接优化器是如何优化join顺序的?
书上说left join, 与right join的联接顺序是固定的
但是对于inner join会自动调整联接顺序, 这个书上没说明白, 我很不理解这个调整联接顺序的依据是什么, 是根据什么原则来确认表的使用顺序?
谢谢大家
------解决方案--------------------
优化器会自动的在内部进行调节,你不需要关心.
原则:他是按照每页4KB的随即读取的开销来选择最低消耗的一个执行计划,然后去执行.
要是你一定要调整他,按照自己要求的顺序去读取的话,则在select 后面直接加 :straight_join 关键字
去指定你自己规定的顺序.
------解决方案--------------------
from A inner join B on A.id=B.id
where b.value=10
这种情况下,换成你自己手工操作,也会先从B表中找出 .value=10 的记录,比如只有10条符合条件,然后再以这 10条B中的记录去A表中逐一找出 A.id=B.id的记录。
------解决方案--------------------
探讨
但是我很困惑, 如果我不能理解mysql是基于什么原则调整联接顺序, 那么我就无法判断mysql是否使用的是最佳顺序, 并且自行调节为最佳顺序
上一篇:MYSQL锁处理
下一篇: mysql 子查询有关问题 求高人指教 急
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
关于mysql临时表的有关问题
取出一个表的最小值 同时 取出 最小值的日期 是怎样写 sql解决方法
求解,一次sql查询出9个父分类,和每个父分类对应的16个二级分类解决方法
写一个loop存储过程怎么写
锛堣浆杞斤級MySQL鐨刲og-bin鐨勬棩蹇楀姛鑳
为什么mysql安装在C盘可以启动服务,安装在D盘不可以启动服务?解决方法
解决qt mysql出现的:无法加载驱动有关问题
'mysql' 不是内部或外部命令,也不是可运行的程序或批处理文件的解决方法
(转)MySQL 汉语言插入数据乱码(问号?)
推荐阅读
更多>
mysql存储过程能动态定义光标吗?解决方法
mysql中hash目录和btree索引
无法给mysql数据库添加用户,该如何解决
mysql查看表构造命令
mysql中生成日期列表,该如何解决
mysql索引相关有关问题
mysql NULL 值求和有关问题
struts2+ibatis+mysql分页兑现
怎么把SQL查询语句写入存储过程执行
mysqldump备份复原和mysqldump导入导出语句大全详解 转
学习上MySQL主辅同步
ubuntu装配mysql的方法(tar文件)
MySQL: 批改默认编码
mysql的 IP 登录 批改
请教为什么在命令行中执行sql 语句与在程序中执行速度差别极大
win7的mysql ERROR #2013 - Lost connection试了很多天都不行,虚心求指点,该如何处理
奇怪 update join 2表不同的写法执行时间差很远,该怎么处理
MySql装配及启动
200w的数据,问上相关查询效率的有关问题
在MySql中怎么将一张表的内容更新到另一张表中