在ORDER BY 子句中加入主键或唯一键

本文通过一个具体的例子说明了在SQL查询中正确使用ORDERBY子句的重要性,特别是当需要确定唯一记录时,应确保ORDERBY包含足够的字段来区分记录。

----start

ORDER BY 子句非常简单,正因为简单,很多人不太在意,随意使用ORDER BY子句很可能出现逻辑错误,考虑如下情况:

假设让你查找一下年龄最小的学生,我们很自然的会写出如下SQL:

 

遗憾的是,上面的语句并不总是正确的,因为张三和李四的年龄是相同的,我们应该把学号(ID)添加在ORDER BY子句中,正确的SQL如下:

 

只要是ORDER BY子句中没有主键或唯一键,就有可能出现上面的情况,所以作为一条规则,我们应该在ORDER BY 子句中加入主键或唯一键。

---更多参见:DB2 SQL 精萃

----声明:转载请注明出处。

----last updated on 2010.1.9

----written by ShangBo on 2010.1.9

----end

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值