Oracle 在 ORDER BY 子句中加入主键或唯一键
来源:互联网 发布:ubuntu的linux修改ip 编辑:程序博客网 时间:2024/05/17 01:42
-- Start
ORDER BY 子句非常简单,正因为简单,很多人不太在意,随意使用ORDER BY 子句很可能出现逻辑错误,考虑如下情况:
CREATE TABLE STUDENT(STUDENT_ID NUMBER(9,0),---学号NAME VARCHAR(20) NOT NULL,---姓名BIRTHDAY DATE---生日);ALTER TABLE "STUDENT" ADD CONSTRAINT "PK_STUDENT" PRIMARY KEY ("STUDENT_ID");INSERT INTO STUDENT (STUDENT_ID,NAME,BIRTHDAY) VALUES (1,'张三',DATE '1991-01-01');INSERT INTO STUDENT (STUDENT_ID,NAME,BIRTHDAY) VALUES (2,'李四',DATE '1991-01-01');INSERT INTO STUDENT (STUDENT_ID,NAME,BIRTHDAY) VALUES (3,'王五',DATE '1990-01-01');
假设让你查找一下年龄最小的学生,我们很自然的会写出如下SQL:
SELECT * FROM (SELECT * FROM STUDENT ORDER BY BIRTHDAY) WHERE ROWNUM=1
遗憾的是,上面的语句并不总是正确的,因为张三和李四的年龄是相同的,我们应该把学号(STUDENT_ID)添加在ORDER BY 子句中,正确的SQL 如下:
SELECT * FROM (SELECT * FROM STUDENT ORDER BY BIRTHDAY, STUDENT_ID) WHERE ROWNUM=1
只要是ORDER BY 子句中没有主键或唯一键,就有可能出现上面的情况,所以作为一条规则,我们应该在ORDER BY 子句中加入主键或唯一键。
-- 更多参见:Oracle SQL 精萃
-- 声明:转载请注明出处
-- Last edited on 2015-06-19
-- Created by ShangBo on 2015-06-19
-- End
0 0
- 在ORDER BY 子句中加入主键或唯一键
- Oracle 在ORDER BY 子句中加入主键或唯一键
- Oracle 在 ORDER BY 子句中加入主键或唯一键
- 在视图中使用ORDER BY子句
- ORDER BY 子句中的列 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中
- Oracle DB Order By子句
- oracle-order by 子句说明
- order by居然不能直接在union子句中使用
- order by居然不能直接在union子句中使用
- Oracle之where子句和order by子句
- SQL语句加入order by 子句之后的效率问题
- Order by 子句
- SQL ORDER BY 子句
- SQL ORDER BY 子句
- ORDER BY 子句用法
- SQL ORDER BY 子句
- SQL ORDER BY 子句
- ORDER BY子句
- 纯CSS3实现动画不规则的tab标签切换代码
- 《Java程序设计》第14周实验作业:GUI编辑初步
- android开机启动代码
- RTL8111/RTL8168 Network Connection Fix
- 韶华渐渐消失 落了一地纸屑
- Oracle 在 ORDER BY 子句中加入主键或唯一键
- Myeclipse下java.lang.OutOfMemoryError: Java heap space的解决
- android隐藏以及显示软键盘以及不自动弹出键盘的方法
- iOS 5.0 后UIViewController新增方法
- GRE词汇下载:与希腊神话有关的词汇
- [Android Studio 权威教程]AS构建系统-Gradle
- Android中获得上下文的静态方法
- 位图索引
- 动态规划题目总结(持续更新)