gpt4 book ai didi

sql - Oracle SQL - 了解 Dual 表如何发挥其魔力

转载 作者:行者123 更新时间:2023-12-02 05:30:04 26 4
gpt4 key购买 nike

在制作一个小型测试表的过程中,我在网上偶然发现了以下文章:( http://www.techonthenet.com/sql/insert.php ) 给出了以下关于如何在 Oracle 中插入多行固定值的解决方案:

Insert All
Into testTable (key, field1, field2) Values (1, 10, 'a')
Into testTable (key, field1, field2) Values (2, 20, 'b')
Into testTable (key, field1, field2) Values (3, 30, 'c')
Into testTable (key, field1, field2) Values (4, 40, 'd')
Select * from dual;

dual 的使用是我以前从未见过的,所以我开始做一些研究来了解它是如何工作的。我知道这个表是某些 Oracle 语法的解决方法,但它如何完​​成这些任务仍然不适合我。我知道其他人也问过类似的问题( How does Oracle SELECT FROM dual work with multiple fields ),但我还没有看到有人解释幕后到底发生了什么。

  • 这是他们能够使用单值表实现的引用技巧,还是 Oracle 中的某些函数只是硬编码为在看到双表时采取不同的行为?

  • 更具体地说,引用它如何允许上面的代码本质上循环多个 Into ... Values ... 语句?

有人可以向我解释一下吗?

最佳答案

从功能上来说,dual只是一个单行表,您碰巧可以指望它始终存在并且始终只有 1 行。您可以轻松创建自己的单行表并使用它来代替 dual 。或者您可以使用您知道始终返回 1 行的查询(即 select * from all_objects where rownum < 2 )。

在幕后,Oracle 能够针对 dual 优化查询比您创建的单行表多一点。优化器知道表始终只有 1 行,因此它可以基于此进行优化。 Oracle 甚至可以消除使用 "fast dual" operation 访问表的需要。以避免执行任何逻辑 I/O。这些优化并不是您在这样的查询中会注意到的事情,当您执行诸如点击 dual 之类的操作时,它们可能很有用。在紧密循环中计算各种表达式。

在本例中 select * from dual只因为多表而存在INSERT语句需要一个查询作为源。通常,当您创建多表时 INSERT ,您可以从源中选择数据并将其部分或全部插入到多个表中。但在本例中,您实际上并未使用来自 SELECT 的数据。语句根本不重要,因此您选择什么或从中选择数据并不重要。

关于sql - Oracle SQL - 了解 Dual 表如何发挥其魔力,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19733018/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com