4

在制作一个小测试表的过程中,我偶然发现了以下在线文章:(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 语法的解决方法,但它如何完​​成这些任务仍然不是我想要的。我知道其他人也问过类似的问题(Oracle SELECT FROM dual 如何与多个字段一起工作),但我还没有看到有人解释引擎盖下的实际情况。

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

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

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

4

1 回答 1

6

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

在幕后,Oracle 能够针对dual您创建的单行表优化查询。优化器知道该表总是正好有 1 行,因此它可以基于此优化事物。Oracle 甚至可以消除使用“快速对偶”操作来避免执行任何逻辑 I/O 的需求。这些优化不是您在这样的查询中会注意到的那种事情,当您执行诸如dual在紧密循环中计算各种表达式之类的事情时,它们可能很有用。

在这种情况下,select * from dual唯一存在是因为多表INSERT语句需要查询作为源。通常,当您创建多表INSERT时,您会从源中选择数据并将其中的部分或全部插入到多个表中。但是,在这种情况下,您实际上并没有使用来自SELECT语句的数据,因此您选择什么或从中选择数据都没有关系。

于 2013-11-01T18:39:27.787 回答