如果是使用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的用法举了一个牵强的例子而已。

最新文章

  1. Javascript获取div真实高度
  2. hdu5438(2015长春赛区网络赛1002)拓扑序+DFS
  3. python 数据类型(sequence 序列、dictionary 词典、动态类型)
  4. JNI 系统钩子
  5. 数据库常用语句sql
  6. Ant简介
  7. Python 基于pykafka简单实现KAFKA消费者
  8. TP5架构下链接SQL数据库的一种方法
  9. echarts 图的点击事件(含:点击重复触发的问题及其解决方法)
  10. 遍历List过程中删除操作报java.util.ConcurrentModificationException错误
  11. 05 自学Aruba之AAA profile无法删除问题
  12. Unity3D学习笔记(三十二):Xlua(2)
  13. linux安装vmware
  14. air 桌面应用发布后可以删除的文件
  15. svn 教程
  16. [Training Video - 6] [File Reading] [Java] Create and Write Excel File Using Apache POI API
  17. MySQL的四种事务隔离级别【转】
  18. Qt类反射机制
  19. tornado 06 数据库—ORM—SQLAlchemy——基本内容及操作
  20. alpha(4/10)

热门文章

  1. ACM-ICPC Beijing Online A The Book List
  2. android--------面试题收集
  3. 正睿 2019 省选附加赛 Day1 T1 考考试
  4. Oracle 使用GSON库解析复杂json串
  5. 使用XML Publisher导出PDF报表
  6. learning uboot enable protect console
  7. [需要补充]javaEE中servlet方法service与doXXX的关系
  8. FR报表 FileName
  9. Flask初级(十)flash与前台交互post详解
  10. ReentrantReadWriteLock——读读共享(一)