oracle查询中表的连接顺序

数据库 Oracle
oracle数据库中,连接了很多表的查询是需要花很多的时间去检测连接这些表的适当顺序的,下文对oracle查询中表的连接顺序作了详细的分析,供您参考。

在oracle查询过程中,对那些连接了很多表的查询,Oracle需要花费大量的时间来检测连接这些表的适当顺序。 oracle查询中表的连接顺序成为了我们需要思考的问题。

评估表的连接顺序

在SQL语句的准备过程中,花费最多的步骤是生成执行计划,特别是处理有多个表连接的查询。当Oracle评估表的连接顺序时,它必须考虑到表之间所有可能的连接。例如:六个表的之间连接有720(6的阶乘,或6 * 5 * 4 * 3 * 2 * 1 = 720)种可能的连接线路。

当一个oracle查询中含有超过10个表的连接时,排列的问题将变得更为显著。对于15个表之间的连接,需要评估的可能查询排列将超过1万亿
(准确的数字是1,307,674,368,000)种。

使用optimizer_search_limit参数来设定限制

通过使用optimizer_search_limit参数,你能够指定被优化器用来评估的***的连接组合数量。使用这个参数,我们将能够防止优化器
消耗不定数量的时间来评估所有可能的连接组合。如果在oracle查询中表的数目小于optimizer_search_limit的值,优化器将检查所有可能的
连接组合。

例如:有五个表连接的查询将有120(5! = 5 * 4 * 3 * 2 * 1 = 120)种可能的连接组合,因此如果optimizer_search_limit等于5
(默认值),则优化器将评估所有的120种可能。optimizer_search_limit参数也控制着调用带星号的连接提示的阀值。当查询中的表的
数目比optimizer_search_limit小时,带星号的提示将被优先考虑。

另一个工具:参数optimizer_max_permutations

初始化参数optimizer_max_permutations定义了优化器所考虑组合数目的上限,且依赖于初始参数optimizer_search_limit。
optimizer_max_permutations的默认值是80,000。

参数optimizer_search_limit和optimizer_max_permutations一起来确定优化器所考虑的组合数目的上限:除非(表或组合数目)
超过参数optimizer_search_limit 或者 optimizer_max_permutations设定的值,否则优化器将生成所有可能的连接组合。一旦优
化器停止评估表的连接组合,它将选择成本***的组合。

使用ordered提示指定连接顺序

你能够设定优化器所执行的评估数目的上限。但是即使采用有很高价值的排列评估,我们仍然拥有使优化器可以尽早地放弃复杂的查询
的重要机会。回想一下含有15个连接查询的例子,它将有超过1万亿种的连接组合。如果优化器在评估了80,000个组合后停止,那么它才
仅仅评估了0.000006%的可能组合,而且或许还没有为这个巨大的查询找到***的连接顺序。

在Oracle SQL中解决此问题的***的方法是手工指定表的连接顺序。为了尽快创建最小的解决方案集,这里所遵循的规则是将表结合起
来,通常优先使用限制最严格的WHERE子句来连接表。

 

 

 

【编辑推荐】

Oracle查询用户表空间的实现

16种oracle查询日期语句

Oracle查询语句应用经验总结

Oracle查询前10条记录的操作方案

oracle查询用户所有表的语句

 

责任编辑:段燃 来源: 互联网
相关推荐

2011-05-20 09:55:26

Oracle连接

2010-04-06 11:02:30

Oracle 数据库

2010-04-08 18:45:35

Oracle数据库

2010-04-07 18:26:43

Oracle数据库

2010-04-08 18:54:32

Oracle数据库

2010-04-06 10:52:06

Oracle数据库

2011-03-21 12:51:16

Oracle数据库表连接

2011-03-11 16:42:51

Oracle数据库视图

2010-10-26 15:21:11

连接Oracle数据库

2016-09-19 10:54:36

C语言静态连接语言

2010-10-26 15:30:12

连接Oracle数据库

2019-11-06 09:30:35

SQL查询语句数据库

2009-11-10 16:00:05

Oracle执行计划

2010-11-15 16:56:52

Oracle COMM

2010-10-29 16:41:12

Oracle模糊查询

2010-10-27 17:00:32

oracle树查询

2010-04-23 16:35:02

Oracle 查询记录

2010-09-08 17:29:37

SQL表变量

2011-03-28 10:17:39

sql server

2010-04-20 08:53:42

Oracle左连接
点赞
收藏

51CTO技术栈公众号