select语句返回结果的顺序问题 .
今天看到论坛上一个朋友的回帖内容,突然意识到自己好像从来没对SELECT语句做过任何思考,即便SELECT是平时使用最多的语句。自己建了两个测试表,内容如下:
- 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
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、先进行两个表的简单连接查询
- 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
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,我就以为上面这两条查询语句将会返回一样的结果,可是实践证明我的想法是错误的,返回的结果顺序是不一样的。
别着急,看看下面这个语句的返回结果,可能你会想到些什么
- 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
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子句的情况
- 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
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相关的问题再加好了。
select语句返回结果的顺序问题 .的更多相关文章
- {MySQL的逻辑查询语句的执行顺序}一 SELECT语句关键字的定义顺序 二 SELECT语句关键字的执行顺序 三 准备表和数据 四 准备SQL逻辑查询测试语句 五 执行顺序分析
MySQL的逻辑查询语句的执行顺序 阅读目录 一 SELECT语句关键字的定义顺序 二 SELECT语句关键字的执行顺序 三 准备表和数据 四 准备SQL逻辑查询测试语句 五 执行顺序分析 一 SEL ...
- SQL Select语句完整的执行顺序(转)
SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...
- 【SQL】SQL 中Select语句完整的执行顺序
SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...
- 170607、SQL Select语句完整的执行顺序
SQL Select语句完整的执行顺序: 1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函 ...
- sql中select语句的逻辑执行顺序
下面是SELECT语句的逻辑执行顺序: FROMONJOINWHEREGROUP BYWITH CUBE or WITH ROLLUPHAVINGSELECTDISTINCTORDER BYTOP M ...
- Oracle中Select语句完整的执行顺序
oracle Select语句完整的执行顺序: .from 子句组装来自不同数据源的数据: .where 子句基于指定的条件对记录行进行筛选: .group by子句将数据划分为多个分组: .使用聚集 ...
- Select语句完整的执行顺序
Select语句完整的执行顺序:1.from子句组装来自不同数据源的数据:2.where子句基于指定的条件对记录行进行筛选:3.group by子句将数据划分为多个分组:4.使用聚集函数进行计算:5. ...
- SQL Select语句完整的执行顺序
1.from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将数据划分为多个分组: 4.使用聚集函数进行计算: 5. 使用having子句筛 ...
- Oracle SQL开发 之 Select语句完整的执行顺序
查询语句语法: Select 属性 From 表 Where 条件 Group by 分组条件 Having 分组选择条件 Order by 排序条件 1.from子句组装来自不同数据源的数据: 2. ...
随机推荐
- Virtual Environments
virtualenv 再另一篇随笔中已经提到过virtualenv.如果我们有好几个不同的项目,他们需要的第三方包版本不同,那怎么办呢.这时候就需要virtualenv创建一个虚拟环境,里面包含了一个 ...
- js的eval方法
eval方法: 检查JScript代码,并且执行. 语法: eval(codeString); 参数: codeString是必选项,参数是包含有效的JScript代码的字符串值,这个字符串值将由JS ...
- Typecho 代码阅读笔记(三) - 插件机制
转载请注明出处:http://blog.csdn.net/jh_zzz 以 index.php 为例: /** 初始化组件 */ Typecho_Widget:: widget('Widget_Ini ...
- Eclipse中设置条件断点
1.在要添加断点的变量那一行前双击,添加断点: 2.在该断点处点击鼠标右键,在弹出的选项卡中选择“断点属性”Breakpoint Properties; 3.在断点属性选项卡中勾选Enabled复选框 ...
- C#设置标记方法等为否决的不可用
C#如何标记类里面的方法或者类为否决的,不可使用.在VS IDE编辑器中使用此方法或者类时会用绿色的波浪线标记这个语句,当移动鼠标到这句代码上时,会出现[否决的]方法名,警告“方法名称”已过时: ...
- SSRS 请求并显示SharePoint人员和组字段
场景: 使用Reporting Service请求SharePoint List,该list中包含人员和组字段.要求:只显示人员或组的display name.示例如下: 项目 参与人员 期望显示 项 ...
- Linux用户与用户组,UID及GID
以下列出文章: Linux系统下如果查看用户的UID和GID:http://blog.csdn.net/ahangliu/article/details/7567444 Linux的用户和用户组管理: ...
- 【HDU 2586 How far away?】LCA问题 Tarjan算法
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2586 题意:给出一棵n个节点的无根树,每条边有各自的权值.给出m个查询,对于每条查询返回节点u到v的最 ...
- android笔试题集2
1.请谈一下Android系统的架构.答:Android系统采用了分层架构,从高层到低层分别是应用程序层.应用程序框架层.系统运行库层和linux核心层. 2.谈谈android大众常用的五种布局.答 ...
- kaggle之旧金山犯罪
kaggle地址 github地址 特点: 离散特征 离散特征二值化处理 数据概览 import pandas as pd import numpy as np # 载入数据 train = pd.r ...