- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在制作一个小型测试表的过程中,我在网上偶然发现了以下文章:( 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/
在 Play 1.x 中有很棒的 play Idealize(和 play eclipsify),它为您最喜欢的 IDE 中的 Play 项目准备了项目文件。 我看到这是在 Play 2.X 中删除的
我是一名优秀的程序员,十分优秀!