多个表左连接 先连大表还是小表_优化必备基础:Oracle中常见的三种表连接方式...

在Oracle SQL语句中,如果from后面有多个表时,表的连接方式是一个很重要的考量。

e84fa6644ebcd66ce7c097efb97921f2.png

从Oracle 6开始,优化器就支持下面4种表连接方式:

— 嵌套循环连接(Nested Loop Join)

— 群集连接(Cluster Join)

— 排序合并连接(Sort-Merge Join)

— 笛卡尔连接(Cartesian Join)

在Oracle 7.3中,新增加了哈希连接(Hash Join)。

在Oracle 8中,新增加了索引连接(Index Join)。

在这些表连接的方法中,Nested Loop Join和Hash Join及Sort-Merge Join是比较常见的。

(1)Nested Loop Join

这种场景一般适用于大表和小表的关联,准确来说应该是大的行集与小的行集,一般小表适用为驱动表,对于小表中的匹配记录和大表做关联,此时小表是在外部循环,大表在内部循环,小表中的记录都和大表做一个关联。

SQL> create table t as select *from dba_objects where object_id is not null;

SQL> create table t1 as select *from user_objects where object_id is not null;

SQL&g

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值