zoukankan      html  css  js  c++  java
  • 在oracle的连接(join)中使用using关键字

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

  • 相关阅读:
    AS3邮件
    JavaScript中this关键字使用方法详解
    AS3嵌入字体
    xp双击打不开jar包解决方案
    查询在表1表2中都存在,在表3中不存在的SQL(前提:表结构相同)
    这是否为复制Bug?求解!
    批处理添加允许弹出临时窗口站点
    SQL Server 合并IP
    C#学习笔记一(变量、属性、方法,构造函数)
    SQLServer事务的隔离级别
  • 原文地址:https://www.cnblogs.com/rongfengliang/p/3706112.html
Copyright © 2011-2022 走看看