在制作一个小测试表的过程中,我偶然发现了以下在线文章:(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 ... 语句?
有人可以向我解释一下吗?