在oracle的连接(join)中使用using关键字 (转)
来源:互联网 发布:圣女贞德 知乎 编辑:程序博客网 时间:2024/04/30 00:17
在oracle的连接(join)中使用using关键字 (转)
在oracle的连接(join)中使用using关键
前面我们介绍了在oralce中使用natural join,也就是自然连接。在Oracle中的join连接中使用using关键字,是相对于natural join的。
我们在前面提到,如果是使用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的用法举了一个牵强的例子而已。
这里还需要说明的是:
<!--[if !supportLists]-->1. <!--[endif]-->如果在使用using关键字时,而且select的结果列表项中包含了using关键字所指明的那个关键字,那么请不要在select的结果列表项中对该关键字指明它属于哪个表,例如如果使用using(prod_id),而在结果列表中要包含prod_id字段的话,请不要写成sales.prod_id或者costs.prod_id而应该写成prod_id,而且也不要使用别名,就是使用例如prod_id as “产品编号”的形式。
<!--[if !supportLists]-->2. <!--[endif]-->using中仅能使用一个列名。
<!--[if !supportLists]-->3. <!--[endif]-->natural join关键字和using关键字是互斥的,也就是说不能同时出现。
- 在oracle的连接(join)中使用using关键字
- 在oracle的连接(join)中使用using关键字
- 在oracle的连接(join)中使用using关键字
- 在oracle的连接(join)中使用using关键字 (转)
- 在oracle连接(join)中使用using关键字
- oracle连接(join)中使用using关键字
- 表连接JOIN,USING子句的使用
- Oracle中的Join(连接)的使用
- oracle使用using关键字
- oracle使用using关键字
- 在Oracle中使用关键字
- Hibernate中outer-join、lazy 、fetch join关键字的使用
- Hibernate中outer-join、lazy 、fetch join关键字的使用
- Hibernate中outer-join、lazy 、fetch join关键字的使用
- oracle join关键字使用总结
- C#中using关键字的使用介绍
- C#中using关键字的使用介绍
- C#中using关键字的使用
- 错排 与 组合
- 关于PHP字符串截取显示相同长度的字符以及UTF8下的ASCII编码
- Android自定义对话框(Dialog)位置,大小
- struts2 Action!jobpage.action后面传参数
- Map缓存适配成带生存期的缓存
- 在oracle的连接(join)中使用using关键字 (转)
- android 利用重力感应监听 来电时翻转手机后静音。
- android lcd调试 高通平台lcd调试深入分析总结(mipi和rgb接口)
- python type函数
- JQuery判断元素是否隐藏
- 通过按键点击实现动态切分窗口的方法
- 单点登录原理
- android textview 使用html实现下划线效果
- 基于XMPP实现的Openfire的配置安装+Android客户端的实现