博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在oracle的连接(join)中使用using关键字
阅读量:5943 次
发布时间:2019-06-19

本文共 767 字,大约阅读时间需要 2 分钟。

如果是使用natraul join,并且两张表中如果有多个字段是具有相同的名称和数据类型的,那么这些字段都将被oracle自作主张的将他们连接起来。

但实际上我们有时候是不需要这样来连接的。我们只需要将他们的多个具有相同的名称和数据类型的字段中挑选一两个。这时候我们就需要用到using 关键字了。

下面是一个例子。

在oracle的例子sh的schema中的有一个表是sales,还有一个表是costs,这两个表中都有两个字段分别是pro_id和time_id。我们暂且不去考虑下面连接的实际意义,仅作语法上的研究。

如果使用natural连接,默认情况下,两个字段将会被自然地连接在一起。

Select * from

Sales natural join costs;

Select * from

Sales join costs on Sales.prod_id = costs.prod_id and sales.time_id = costs.time_id

Select * from

Sales ,costs

Where Sales.pro_id = cost.prod_id

and sales.time_id = costs.time_id

得到的结果应该是一样的。

如果我们使用自然连接,就没有机会控制连接条件,oracle自作主张的将两个相同数据类型和名称的字段自然地连接在一起了。

下面我们使用using关键字。

Select * from

Sales join costs using(prod_id)

这样就迫使oracle使用using指出的字段来做连接,而不是natural join连接中默认的两个。

请注意,这里的SQL语句没有任何意义,只是为了说明using的用法举了一个牵强的例子而已。

转载地址:http://epwxx.baihongyu.com/

你可能感兴趣的文章
UVa 10902
查看>>
Mathf.Sin正弦
查看>>
禁止浏览器缓存js
查看>>
【Redis】安装PHP的redis驱动(二)
查看>>
什么是序列化,为什么要序列化
查看>>
Java保留小数点后有效数字
查看>>
C++中一些类和数据结构的大小的总结
查看>>
mysql开启binlog
查看>>
ctrl + z fg bg
查看>>
工作流引擎Oozie(一):workflow
查看>>
struct框架
查看>>
Deep Learning(深度学习)相关网站
查看>>
设置Eclipse编码方式
查看>>
分布式系统唯一ID生成方案汇总【转】
查看>>
Cross-compilation using Clang
查看>>
并查集hdu1232
查看>>
oracle进行字符串拆分并组成数组
查看>>
100多个基础常用JS函数和语法集合大全
查看>>
Java8 lambda表达式10个示例
查看>>
innerHTML outerHTML innerText
查看>>