86标准SQL与92标准SQL用法区别

在开发Oracle 9i时,
数据库还时间了ANSL SQL/92标准的链接语法, 在书中建议在使用Oracle 9i及更高版本时,应该使用SQL/92标准的语法;在使用Oracle 8i 及更低版本时,应该使用SQL/86标准的语法。 -----《Oracle Database 10g SQL 开发指南》

86标准sql是传统的表连接写法,就是直接将表写在FROM后边,将表连接条件与过滤条件都写在WHERE后边。

92标准SQL是采用JOIN的表连接方法。分为LEFT JOIN,RIGHT JOIN,INNER JOIN,每一种JOIN方法都可以使用86版SQL转化得到相应写法,但并不是完全相同。

下面举例说下两种表连接的用法:

测试数据:

create table a (id integer,name varchar(20));

create table b (id integer,name varchar(20));

create table c (id integer,name varchar(20));

insert into a values(1,'a1');

insert into a values(2,'a2');

insert into a values(3,'a3');

insert into a values(4,'a4');

insert into a values(5,'a5');

insert into b values(2,'b2');

insert into b values(3,'b3');

insert into b values(4,'b4');

insert into b values(5,'b5');

insert into b values(6,'b6');

insert into c values(1,'c1');

insert into c values(2,'c2');

insert into c values(3,'c3');

insert into c values(4,'c4');

1: 等值连接 INNER JOIN

SQL> select a.id,a.name,b.id,b.name,c.id,c.name

2 from a inner join b on a.id=b.id

3 inner join c on a.id=c.id ;

ID NAME ID NAME ID NAME

--------- -------------------- ---------- -------------------- ---------- ----

2 a2 2 b2 2 c2

3 a3 3 b3 3 c3

4 a4 4 b4 4 c4

以上92版SQL 与以下86版SQL结果相似;

select a.id,a.name,b.id,b.name,c.id,c.name

from a ,b ,c 

where a.id=b.id

and a.id=c.id

2:左连接 left join

先看92两种写法得到的结果对比一下。

SQL> select a.id,a.name,b.id,b.name,c.id,c.name

2 from a left join b on a.id=b.id

3 left join c on b.id=c.id ;

ID NAME ID NAME ID NAME

---------- -------------------- ---------- -------------------- ---------- -----

---------------

2 a2 2 b2 2 c2

3 a3 3 b3 3 c3

4 a4 4 b4 4 c4

1 a1

5 a5 5 b5

SQL> select a.id,a.name,b.id,b.name,c.id,c.name

2 from a left join b on a.id=b.id

3 left join c on a.id=c.id ;

ID NAME ID NAME ID NAME

---------- -------------------- ---------- -------------------- ---------- -----

---------------

2 a2 2 b2 2 c2

3 a3 3 b3 3 c3

4 a4 4 b4 4 c4

5 a5 5 b5

1 a1 1 c1

两种写法都是左连接,唯一不同的就是与表C进行连接时的连接条件不同。但得到的结果却完全不同。

在处理C表时,数据库判定左接连基准表的依据是ON 后边的连接条件。对于第一个SQL(b.id=c.id),C表是和处理过的B表的结果集进行

连接,从B表得到结果集中ID取值为2,3,4,5 。以此为结果为基准再与C表进行连接,因此,从C表中得到的符合条件数据的ID为2,3,4

对于第二个SQL,C表是和A表进行连接,因为自始至终A表都是左连接中的基准表,所以表中的数据量不变,C表再与之进行左连接时得到的结果集中的ID为1,2

,3,4

对于以上两种SQL的写法,分别可以用以下写法代替

第一条SQL:

select a.id,a.name,b.id,b.name,c.id,c.name

from a ,b ,c 

where a.id=b.id(+)

and b.id=c.id(+) 

第二条SQL 

select a.id,a.name,b.id,b.name,c.id,c.name

from a ,b ,c 

where a.id=b.id(+)--b表和a表进行左连接,以a表为准,称为左连接。注意哦,(+)是放在右边的

and a.id=c.id(+)--c表和a表进行左连接,以a表为准

3:右连接 

92版SQL写时,只需将LEFT换成RIGHT就可以了。 86版SQL,只需改变下(+)的位置不可以了。

4:92版sql中的where条件与ON条件

86版中的连接条件与过滤条件都放在WHERE条件后边了。

但92版SQL中,连接条件放在ON 后边,过滤条件放在WHERE 后边。

注意区分,以下两个SQL得到的结果是不同的:

SQL> select a.id,a.name,b.id,b.name

2 from a left join b on a.id=b.id

3 and b.id>2 ;

ID NAME ID NAME

---------- -------------------- ---------- ----------

3 a3 3 b3

4 a4 4 b4

5 a5 5 b5

1 a1

2 a2



SQL> select a.id,a.name,b.id,b.name

2 from a left join b on a.id=b.id

3 where b.id>2 ;

ID NAME ID NAME

---------- -------------------- ---------- -----

3 a3 3 b3

4 a4 4 b4

5 a5 5 b5

虽然是相同的条件,但 放的位置不同,得到的结果不同。

对于第一个SQL。 b.id>2 是在进行表连接的时候对B表的数据进行过滤。

但对于第二个SQL, b.id>2 是对结果集进行过滤。

以上两种SQL的写法对应到86版SQL时的写法是:

select a.id,a.name,b.id,b.name

from a ,b

where a.id=b.id(+)

and b.id>2

它是与第二个SQL的结果保持一至的(这个地方一直怀疑,应该是数据库根据不同情况来应用b.id>2为驱动条件还是过滤条件,试验了发多数据,都没有得到是把 b.id>2当作驱动条件来使用的,都是当成过滤条件)。

原文地址:

http://hi.baidu.com/420350501/blog/item/dd5344f15d010c3cbd3109fc.html

http://www.itpub.net/thread-919997-1-1.html

86标准SQL与92标准SQL用法区别的更多相关文章

  1. 关于Oracle SQL/82标准和SQL/92标准

    在ORACLE9i之前,oracle语法基础是SQL/86标准,9i及之后的版本中支持SQL/92标准.基表信息:products.purchases和product_types SQL> se ...

  2. go标准库的学习-database/sql

    参考:https://studygolang.com/pkgdoc 导入方式: import "database/sql" sql包提供了保证SQL或类SQL数据库的泛用接口. 使 ...

  3. 第三百九十二节,Django+Xadmin打造上线标准的在线教育平台—sql注入攻击,xss攻击,csrf攻击

    第三百九十二节,Django+Xadmin打造上线标准的在线教育平台—sql注入攻击,xss攻击,csrf攻击 sql注入攻击 也就是黑客通过表单提交的地方,在表单里输入了sql语句,就是通过SQL语 ...

  4. SQL Server 2008各版本介绍区别(包含企业版 开发者版 标准版 Web版 工作组版 Express版 Compact版)

    SQL Server 2008分为SQL Server 2008企业版.标准版.工作组版.Web版.开发者版.Express版.Compact 3.5版,其功能和作用也各不相同,其中SQL Serve ...

  5. SQL Server 中 GO 的用法(转)

    本科里学了那么多年SQL Server一直看到书上各种SQL语句中间夹杂着那么几个看似毫无意义的GO,看着就让人莫名,问老师,老师一般只会告诉你,不要理他,这个东西没用的.但是个性纠结并且有轻微强迫症 ...

  6. sql事务(Transaction)用法介绍及回滚实例

    sql事务(Transaction)用法介绍及回滚实例 事务(Transaction)是并发控制的单位,是用户定义的一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的工作单位.通过事务, S ...

  7. 转 SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题

    SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题 SQL Union和SQL Union All用法 SQL UNION 操作符 UN ...

  8. sql语句中charindex的用法 可用于截取字符串

    使用CHARINDEX和PATINDEX函数来搜索文字列和字符串.这两个函数是如何运转的,解释他们的区别.同时提供一些例子,通过这些例子,你可以可以考虑使用这两个函数来解决很多不同的字符搜索的问题. ...

  9. SQL SERVER 中 GO 的用法2

    具体不废话了,请看下文详解. 1 2 3 4 5 6 7 8 9 10 use db_CSharp go  select *,  备注=case  when Grade>=90 then '成绩 ...

随机推荐

  1. t60替换alt,super,ctrl

    发现T60的左边在ctrl 与 alt 有个win 键,所以就进行了映射 网上有一个把alt->ctrl, super-> alt, ctrl->super的script, 见 ht ...

  2. new() 和 make() 的区别

    https://github.com/Unknwon/the-way-to-go_ZH_CN/blob/master/eBook/07.2.md

  3. 我的Java开发学习之旅------>计算从1到N中1的出现次数的效率优化问题

    有一个整数n,写一个函数f(n),返回0到n之间出现的"1"的个数.比如f(1)=1:f(13)=6,问一个最大的能满足f(n)=n中的n是什么? 例如:f(13)=6, 因为1, ...

  4. 我的Java开发学习之旅------>使用Working Setst将Eclipse中的项目分类使项目一目了然

    今天发现Eclipse中若有太多的项目,杂七杂八的,看起来会非常的痛苦.今天请教公司的前辈学会了一个方法,在Eclipse中,当项目比较多的时候,我们可以用WorkingSet将这些项目分类,把相关连 ...

  5. mapreduce的一个模版

    import java.io.IOException; import java.text.DateFormat; import java.text.SimpleDateFormat; import j ...

  6. struts 与 Java Web应用简介

    struts实质上就是JSP Model2的基础上实现的MVC框架. 在Struts框架中,模型有实现业务逻辑的JavaBean或EJB组件构成 视图由一组JSP文件构成. 控制器 控制器由Actio ...

  7. API的理解和使用——单线程架构

    核心知识点: 1.单线程机制:所有命令放在一个队列中 2.为什么Redis单线程这么快?内存中执行.非IO阻塞.避免线程切换和竞态产生的消耗. 3.单线程的问题?一个命令不能执行太长时间,不然会阻塞其 ...

  8. Java for LeetCode 096 Unique Binary Search Trees

    Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For examp ...

  9. View源码-Touch事件

    在Android-27中查看源码: 首先我们来查看单个View的触摸事件的处理,在View的dispatchTouchEvent方法中看看源码是如何处理的. public boolean dispat ...

  10. jzyz集训 0612

    今天闵神找的题,题目质量还算不错,就是有些偏套路了. 第一题:定义一个排列是合法当且仅当这个排列中不存在大于2的循环节,询问有多少长度为n的排列是合法的且B排列是该排列的子序列. 恩...这题目其实不 ...