oraclehashjoin怎么使用(oracle创建hash索引语句)

技术Oracle数据库中hash join和nested loop怎么用这篇文章主要为大家展示了“Oracle数据库中hash join和nested loop怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,

本文主要展示“如何在Oracle数据库中使用散列连接和嵌套循环”,简单易懂,组织清晰。希望能帮你解开疑惑。让边肖带领大家学习《如何在Oracle数据库中使用散列连接和嵌套循环》一文。

Oracle表连接方法-嵌套循环连接和排序合并连接

关系数据库技术的本质是通过关系表存储标准化的数据,通过各种表连接技术和各种类型的索引技术来检索和处理信息。

表的三种关联方式:

嵌套循环:从表A中提取一条记录,遍历表B找到匹配的记录,然后从表A中提取下一条记录,遍历表B.它是一个双循环hashjoin:根据连接键从表A中计算出一个哈希表,然后从表B中逐个提取记录,计算出哈希值,根据哈希值的哈希值将符合条件的记录匹配到表A中sortmergejoin:将表A和表B都放好顺序。

对于三种连接,我们可以使用提示来强制优化器离开:use_hash、use_nl、use_merge。

Nested Loop Join

1.实施原则

例如:

选择1。*,t2。* fromt1,t2其中t1 . col 1=T2 . col 2;

访问机制如下:

forin(从t1中选择*)循环-t1是驱动表。

forjin(选择* from 2 herecol 2=I . col 1)循环

显示结果;

endloop

endloop

就像嵌套循环。

执行嵌套循环时,首先外循环进入内循环,然后内循环终止。

然后,执行外部循环,然后从外部循环进入内部循环。当外部循环完全终止时,程序结束。

2.步骤如下

A.确定驾驶台

B.将内部表分配给驱动程序表

C.对于从动表的每一行,访问从动表的所有行。

3.实施计划如下

NESTEDLOOPS

外环驱动表

内环

当优化器模式为FIRST_ROWS时,我们经常会发现大量的NESTEDLOOP。

此时,在向用户返回数据时,我们不需要缓存任何数据,这是nestedloop的一大亮点。

使用场景

一般在连接表中有索引,索引选择性好(即选择性接近1)时使用。

也就是说,驱动表的记录集相对较小(10000),内表需要有效的访问方法(Index)。

需要注意的是,JOIN的顺序很重要,驱动表的记录集一定要小,返回结果集的响应时间最快。

5.与指数的关系

嵌套循环和索引就像孪生兄弟,一般需要一起考虑和设计,从优化器的执行机制就可以看出来。

例如,有两个表,一个有10条记录,一个有1000万条记录。

以小表为驱动表,成本为:10*(通过索引查询大表中一条记录的成本)

如果没有1000万大表的索引,那么成本可想而知。

因此,在连接多个表时,要注意被驱动表的连接字段是否需要创建索引。

或者是否需要在表的连接字段和其他约束字段上创建复合索引Sort Merge Join

1.实施原则

选择1。*,t2。* fromt1,t2其中t1 . id=T2 . id;

访问机制如下:

访问t1和orderbyt1_1.id,其中id代表连接字段。

访问t2并按T2 1 . id订购

Joint1_1.id=t2_1.id,依次交替比较合并,不过驱动也没关系。

2.使用场景

虽然是用hashjoin代替sj,但是如果你的服务器的CPU资源和MEM资源非常紧张,建议使用SORTMERGEJOIN。

因为hashjoin比sortmergejoin需要更多的资源。尤其是cpu。

10gsqltuning文档内容如下:

另一方面,sort-mergejoinscanperformabeththanhasjoinifsboth of下列条件是匹配的:

该资源已被删除。

操作不需要完成。

因此,当没有索引并且数据已经排序时,可能会使用sj。以上就是“如何在Oracle数据库中使用散列连接和嵌套循环”一文的全部内容。感谢阅读!相信大家都有一定的了解,希望分享的内容对大家有所帮助。想了解更多知识,请关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/144268.html

(0)

相关推荐

  • 怎样理解JavaScript 正则表达式

    技术怎样理解JavaScript 正则表达式今天就跟大家聊聊有关怎样理解JavaScript 正则表达式,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. 正则表

    攻略 2021年11月5日
  • window10上登录Oracle时提示ORA-12546错误怎么办

    技术window10上登录Oracle时提示ORA-12546错误怎么办这篇文章主要介绍window10上登录Oracle时提示ORA-12546错误怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要

    2021年11月20日
  • 配置H3C华三设备远程管理,SSH、Telnet等)

    技术配置H3C华三设备远程管理,SSH、Telnet等) 配置H3C华三设备远程管理(SSH、Telnet等)拓扑如下:
    注:本实验用一台华三路由器模仿真实设备,再一台host主机充当模拟器到本地计算机

    礼包 2021年12月16日
  • swing客户端设置(哪些是swing的界面组件)

    技术Swing客户端的知识有哪些这篇文章将为大家详细讲解有关Swing客户端的知识有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.简介Jakarta Struts

    攻略 2021年12月18日
  • 对孩子的期望和鼓励的话,鼓励孩子学习进步的话十个字

    技术对孩子的期望和鼓励的话,鼓励孩子学习进步的话十个字文:花样年华 原创:花熹(cyp4290) 金秋时节,清风送爽,菊花遍地,开学的集结号即将吹起!孩子们,你们新的征程即将开始了! 陈老师忍不住又要把几句叮咛

    生活 2021年10月21日
  • 生绿豆芽,用塑料瓶生绿豆芽怎么做

    技术生绿豆芽,用塑料瓶生绿豆芽怎么做很高兴回答你的问题需要到的工具材料:大可乐瓶生绿豆芽、剪刀一把、锥子一个步骤一:找个大可乐瓶或者其他大瓶子也行。步骤二:用剪刀在可乐瓶锥形的地方剪开,下面的部门就是圆柱形的容器了。

    生活 2021年10月24日