今天看到论坛上一个朋友的回帖内容,突然意识到自己好像从来没对SELECT语句做过任何思考,即便SELECT是平时使用最多的语句。自己建了两个测试表,内容如下:

  1. SQL> conn scott/tiger
  2. Connected.
  3. SQL> create table a(aid int, name char(1));
  4. Table created.
  5. SQL>
  6. SQL> create table b(bid int, name char(1));
  7. Table created.
  8. SQL> insert into a values(1,'a');
  9. 1 row created.
  10. SQL> insert into a values(2,'b');
  11. 1 row created.
  12. SQL> insert into a values(3,'c');
  13. 1 row created.
  14. SQL> insert into b values(1,'b');
  15. 1 row created.
  16. SQL> insert into b values(2,'c');
  17. 1 row created.
  18. SQL> insert into b values(3,'a');
  19. 1 row created.
  20. SQL> commit;
  21. Commit complete.
  22. SQL> select * from a;
  23. AID N
  24. ---------- -
  25. 1 a
  26. 2 b
  27. 3 c
  28. SQL> select * from b;
  29. BID N
  30. ---------- -
  31. 1 b
  32. 2 c
  33. 3 a

SQL> conn scott/tiger
Connected.
SQL> create table a(aid int, name char(1));

Table created.

SQL>
SQL> create table b(bid int, name char(1));

Table created.

SQL> insert into a values(1,'a');

1 row created.

SQL> insert into a values(2,'b');

1 row created.

SQL> insert into a values(3,'c');

1 row created.

SQL> insert into b values(1,'b');

1 row created.

SQL> insert into b values(2,'c');

1 row created.

SQL> insert into b values(3,'a');

1 row created.

SQL> commit;

Commit complete.

SQL> select * from a;

AID N
---------- -
1 a
2 b
3 c

SQL> select * from b;

BID N
---------- -
1 b
2 c
3 a

1、先进行两个表的简单连接查询

  1. SQL> select a.aid from a,b where a.aid=b.bid;
  2. AID
  3. ----------
  4. 1
  5. 2
  6. 3
  7. SQL> select a.aid from a,b where a.name=b.name;
  8. AID
  9. ----------
  10. 2
  11. 3
  12. 1

SQL> select a.aid from a,b where a.aid=b.bid;

AID
----------
1
2
3

SQL> select a.aid from a,b where a.name=b.name;

AID
----------
2
3
1

起初我看到这两个表中的内容差不多,a.aid和b.bid里都是1、2、3,a.name和b.name里都是a、b、c,我就以为上面这两条查询语句将会返回一样的结果,可是实践证明我的想法是错误的,返回的结果顺序是不一样的。

别着急,看看下面这个语句的返回结果,可能你会想到些什么

  1. SQL> select a.aid from a,b where b.name=a.name;
  2. AID
  3. ----------
  4. 2
  5. 3
  6. 1
  7. SQL> select a.aid from b,a where a.name=b.name;
  8. AID
  9. ----------
  10. 1
  11. 2
  12. 3
  13. SQL> select a.aid from b,a where a.aid=b.bid;
  14. AID
  15. ----------
  16. 1
  17. 2
  18. 3

SQL> select a.aid from a,b where b.name=a.name;

AID
----------
2
3
1
SQL> select a.aid from b,a where a.name=b.name;

AID
----------
1
2
3

SQL> select a.aid from b,a where a.aid=b.bid;

AID
----------
1
2
3

当选用两张表中各自的name字段作为查询条件的时候,如果FROM 子句后面表出现的顺序不同,结果也会有所不同。

当a表出现在后面的时候,那么SELECT 语句选择a中的一条记录,然后去b表中进行扫面,看有没有符合条件的记录,当然a、b、c三个值在b表中都是有的,所以aid的结果依次为1、2、3。

可是当b表出现在后面的时候,那么SELECT语句先选择b表中的一条记录(1,'b'),到a表中进行扫面,看是否有符合条件的记录,这个时候a表中name字段为'b'的记录的响应aid为2,所以2查询结果中2就排在第一位咯。

2、看一看在SELECT中加上ORDER BY子句的情况

  1. SQL> select a.aid from a,b where a.name=b.name order by b.bid;
  2. AID
  3. ----------
  4. 2
  5. 3
  6. 1
  7. SQL> select a.aid from a,b where a.name=b.name order by b.name;
  8. AID
  9. ----------
  10. 1
  11. 2
  12. 3
  13. SQL> select a.aid from a,b where a.aid=b.bid order by b.name;
  14. AID
  15. ----------
  16. 3
  17. 1
  18. 2
  19. SQL> select a.aid from a,b where a.aid=b.bid order by b.bid;
  20. AID
  21. ----------
  22. 1
  23. 2
  24. 3

SQL> select a.aid from a,b where a.name=b.name order by b.bid;

AID
----------
2
3
1

SQL> select a.aid from a,b where a.name=b.name order by b.name;

AID
----------
1
2
3

SQL> select a.aid from a,b where a.aid=b.bid order by b.name;

AID
----------
3
1
2
SQL> select a.aid from a,b where a.aid=b.bid order by b.bid;

AID
----------
1
2
3

经过上面的解释,这个地方就不是很难理解了。

第一个SELECT语句中的ORDER BY B.BID对语句查询结果没有产生什么影响。

对于第二个SELECT语句,在排序前的结果为:

A.AID      B.BID      B.NAME

2             1            b

3             2            c

1             3            a

经过ORDER BY B.NAME了,就变为如下结果了:

A.AID      B.BID      B.NAME

1             3            a

2             1            b

3             2            c

这个时候从这个结果集中选出A.AID,当然就是1、2、3了。

下面两个以A.AID和B.BID的例子比较简单,我就不多说了,基本情况和前面一样,有兴趣的话你也可以对照着想一想这个过程,呵呵。

好了,大概就这些吧,小记一下,以后碰到SELECT相关的问题再加好了。

ORACLE表连接方式可以参考这篇文章

select语句返回结果的顺序问题 .的更多相关文章

  1. {MySQL的逻辑查询语句的执行顺序}一 SELECT语句关键字的定义顺序 二 SELECT语句关键字的执行顺序 三 准备表和数据 四 准备SQL逻辑查询测试语句 五 执行顺序分析

    MySQL的逻辑查询语句的执行顺序 阅读目录 一 SELECT语句关键字的定义顺序 二 SELECT语句关键字的执行顺序 三 准备表和数据 四 准备SQL逻辑查询测试语句 五 执行顺序分析 一 SEL ...

  2. SQL Select语句完整的执行顺序(转)

    SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...

  3. 【SQL】SQL 中Select语句完整的执行顺序

    SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...

  4. 170607、SQL Select语句完整的执行顺序

    SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...

  5. sql中select语句的逻辑执行顺序

    下面是SELECT语句的逻辑执行顺序: FROMONJOINWHEREGROUP BYWITH CUBE or WITH ROLLUPHAVINGSELECTDISTINCTORDER BYTOP M ...

  6. Oracle中Select语句完整的执行顺序

    oracle Select语句完整的执行顺序: .from 子句组装来自不同数据源的数据: .where 子句基于指定的条件对记录行进行筛选: .group by子句将数据划分为多个分组: .使用聚集 ...

  7. Select语句完整的执行顺序

    Select语句完整的执行顺序:1.from子句组装来自不同数据源的数据:2.where子句基于指定的条件对记录行进行筛选:3.group by子句将数据划分为多个分组:4.使用聚集函数进行计算:5. ...

  8. SQL Select语句完整的执行顺序

    1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函数进行计算: 5. 使用having子句筛 ...

  9. Oracle SQL开发 之 Select语句完整的执行顺序

    查询语句语法: Select 属性 From 表 Where 条件 Group by 分组条件 Having 分组选择条件 Order by 排序条件 1.from子句组装来自不同数据源的数据: 2. ...

随机推荐

  1. ArtTemplate 使用笔记

    新一代 javascript 模板引擎:artTemplate-3.0 下载地址:https://github.com/aui/artTemplate 快速上手请参考:https://github.c ...

  2. PHP 中 const define 的区别

    在php中定义常量时,可用到const与define这两种方法,那他们到底有什么区别呢? 1.const用于类成员变量的定义,一经定义,不可修改.define不可用于类成员变量的定义,可用于全局常量. ...

  3. [原]用C#模拟实现扑克牌发牌、排序程序。

    (1)52张扑克牌,四种花色(红桃.黑桃.方块和梅花),随机发牌给四个人. (2)最后将四个人的扑克牌包括花色打印在控制台上. 其中:     花色和点数用枚举类型实现     每张扑克牌用结构实 ...

  4. EF 请求数据是缓存 求大神解释

    // //AliexpressEntities MyaliexpressEntities 为了事物一致性 在别的方法里面传过来的 实质还是 (  AliexpressEntities aliexpre ...

  5. css清除浮动解决方案

    清除浮动包括清除子元素的浮动和清除上级元素的浮动,其中清除上级元素的浮动,只需设置clear为both就可以了,而清除子元素的浮动则可以用空标签法.clearfix方法或overflow方法.因清除上 ...

  6. thinkphp项目目录

    #   ThinkPHP核心文件介绍        ├─ThinkPHP.php     框架入口文件    ├─Common 框架公共文件    ├─Conf 框架配置文件    ├─Extend ...

  7. 信号量 <第六篇>

    一.ManualResetEvent 该对象有两种信号量状态True和False.构造函数设置初始状态. WaitOne:该方法用于阻塞线程,默认是无限期的阻塞,支持超时阻塞,如果超时就放弃阻塞,这样 ...

  8. iframe父子页面互调方法和属性

    1.iframe子页面调用 父页面js函数 子页面调用父页面函数只需要写上window.praent就可以了.比如调用a()函数,就写成: window.parent.a(); 子页面取父页面中的标签 ...

  9. jQuery UI 之 Bootstrap 快速入门

    转载自(http://www.shouce.ren/example/show/s/6444) 1. 下载 这个页面是用来展示 jQuery UI Bootstrap 项目的 -- 我们将 Bootst ...

  10. python使用get在百度搜索并保存第一页搜索结果

    python使用get在百度搜索并保存第一页搜索结果 作者:vpoet mail:vpoet_sir@163.com 注:随意copy,不用在意我的感受 #coding:utf-8 import ur ...