Oracle优化器、优化模式、表的连接方式(Hash Join、Nested Loop、Sort Merge Join)

本文介绍了Oracle的查询优化器,包括基于规则的优化器(RBO)和基于代价的优化器(CBO),并详细讲解了优化模式如FIRST_ROWS。接着,讨论了表的三种连接方式:Hash Join、Nested Loop和Sort Merge Join,分析了它们的工作原理、适用场景及优缺点。优化器通常根据数据量和索引来选择合适的连接方式,而人工也可以通过use_hash提示强制使用特定的连接方式。
摘要由CSDN通过智能技术生成

查询优化器

Oracle的查询优化器(QO)分为两种:
1. RBO:Ruled-Based Optimization, 基于规则的优化器;
2. CBO :Cost-Based Optimization, 基于代价的优化器;

从 Oracle 10g开始,Oracle已放弃RBO,但为了兼容性,仍然可以设置RBO.

优化模式

优化模式分为:
FIRST_ROWS: 尽可能快的先返回几行数据;
FIRST_ROWS_n:包含FIRST_ROWS_1000、FIRST_ROWS_100、FIRST_ROWS_10、FIRST_ROWS_1 和上面类似,只是制定了具体的行数;
ALL_ROWS: 以最快的方式返回所有的记录,这是默认的优化模式;

SQL> show parameter optimizer_mode;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
optimizer_mode
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值