表连接查询的顺序和where子句条件的前后顺序会影响sql的性能么
有好多时候,我们常听别人说大表在前,小表在后,包括现在好多百度出来的靠前的答案都有说数据库是从右到左加载的,所以from语句最后关联的那张表会先被处理。如果三表交叉,就选择交叉表来作为基础表。等等一些结论,但是这些真的正确么?我就回家做了一个小的验证,来看一看到底是怎么一回事。(博主作实验用的是Oracle,但是不代表只是Oracle是这样的原理,现在大部分的关系型数据库都是一样的)
首先我们来执行一下以下的sql语句,来看一下执行计划。看一看到底是怎么样的。
drop table tab_big; --删除原有big表
drop table tab_small;
create table tab_big as select * from dba_objects where rownum<=30000; --创建表,并且插入记录
create table tab_small as select * from dba_objects where rownum<=10;
set autotrace traceonly --开启执行计划和统计信息
set linesize 1000
set timing on
select count(*) from tab_big,tab_small;
select count(*) from tab_small,tab_big;
OK,完事后咱们来看一看,到底表的顺序到底是否会影响到数据库的执行效率,我们来看一下”select count(*) from tab_big,tab_small“和”select count(*) from tab_small,tab_big“的执行计划(图1为大表在前,小表在后。图2为小表在前)
执行完后。我们惊奇的发现,居然他们耗费的资源和时间基本是一模一样的,所以说这个表的顺序会影响sql的执行效率是一个不对的结论,但是大部分网上评论和博客都是这么写的,真的是恶意谣言么?那咱们看一下下面这两条sql的执行效率。
然后我们执行下,下面的这两条sql。
select /*+rule*/ count(*) from tab_big,tab_small;--/*+rule*/基于规则执行
select /*+rule*/ count(*) from tab_small,tab_big;
接下来我们看一下这两条sql的执行计划。(图1为第一条sql大表在前,小表在后,图2为第二条sql,小表在前)
这个时候我们有惊奇的发现,这个就应了网上大部分的答案,说明他们说的也是有道理的。这其中是什么原因呢?根据我在翻阅各种资料和查阅官网后得知:原来早些的数据库版本是基于规则去处理的sql,也就是加上我们的/*+rule*/这个之后。但是现在我们的数据库都是基于代价的,所以也就不存在了表的顺序会影响sql的效率了。那我们的where其实也是一样的道理,也不会因为顺序去影响sql的效率。(where的结论博主也经过了执行验证,但是同理表连接,所以就不贴出来代码了)
最新文章
- C# 委托Delegate(一) 基础介绍&;用法
- css双飞翼布局
- 获取ip的ip138.com
- 安装多JDK后,java编译环境和运行环境版本(JDK版本) 不一致解决:
- AOP 下的权限控制实现
- [转载]ecshop 实现订单导出功能 指定订单导出 EXCEL 数据文件
- UI控件自定义tableView的分割线的样式
- c# 正则表达式的用户
- 和为S的两个数
- libmemcached的安装及測试
- sql server 权限
- React原理探索- @providesModule 模块系统
- Skywalking部署常见问题以及注意事项
- 解决yii2 禁用layout时AppAsset不加载资源的问题
- Mysql Bypass小结
- OSG添加回调更新
- duilib中edit获得鼠标焦点后右边框被覆盖
- windows live writer 2012 0x80070643
- MSSQL中通过关键字查找所有存储过程
- 19-3-13Python中的函数
热门文章
- Github+yeoman+gulp-angular初始化搭建angularjs前端项目框架
- codeforces 591B Rebranding (模拟)
- MongoDB副本集的常用操作及原理
- (原创)性能测试中,Oracle服务器定位CPU使用率高的瓶颈(SQL)
- Java实现八种排序算法(代码详细解释)
- ng-class改变css样式
- 【JAVAWEB学习笔记】02_HTML&;CSS
- Ubuntu 挂载硬盘分区
- 027 hibernate查询语言(HQL)
- TWaver 2D+GIS+3D的试用和在线Demo