设为首页 收藏本站
查看: 970|回复: 0

[经验分享] 关于SQL语句

[复制链接]

尚未签到

发表于 2016-11-9 06:16:16 | 显示全部楼层 |阅读模式
  本文是卢飞大哥的学习心得.
  不同数据库中如何使用SQL来控制返回记录的条数以及常见错误分析
在项目实现中可能需要返回满足条件的几条记录而不是全部记录,如返回一个班的第一名,第二名,第三名学生的记录信息,返回该月所卖出的图书中销量排行前三的图书名等等,当然实现这种功能有很多的方法,这里我近描述用简单的SQL和数据库的属性或函数来实现该功能。(以下示例仅选取五条记录)
1. MySql
SELECT field1, field2, field3 [,……] FROM Table_Name limit 5
2. Oracle
SELECT field1, field2, field3 [,……] FROM Table_Name WHERE ROWNUM<= 5
3. SQL Server
SELECT  TOP(5)  FROM Table_Name
这里的语句都比较简单,一看就明白, 但是在数据库中是如何进行筛选记录的呢? 这里我就是用Oracle的语句来讲述,仅仅是个人理解,如果有什么不对请留言告知,一切以学习为主.
言归正传,在Oracle中执行SELECT field1, field2, field3 [,……] FROM Table_Name WHERE ROWNUM<= 5主要分以下几步来实现:
1. Oracle 执行SQL从数据库中找出所有的满足条件的记录。
2. 获取第一条记录,并且设置ROWNUM的值为1.
3. 判断ROWNUM是否<=5, 如果小于或等于5Oracle返回该记录,如果大于5Oracle就不返回该条记录。
4. Oracle继续获取下一条记录,如果3成功获取了一条记录,则ROUNNUM的值就会加1,并用来标识第二条的记录,否则ROUNNUM保持不变。
5. 继续第3步,一直到找到五条记录或便利完所有的记录是结束。
以上仅仅个人理解,下面我就用一个常见的错误来结束本文。
现在有很多人使用Oracle写的选择记录条数的SQL语句如下, 先不要看后文,不知道你认为下面的两个语句的输出结果是怎么样的,如果在有足够的相应的记录的情况下。
1. SELECT field1, field2, field3 [,……] FROM Table_Name WHERE ROWNUM = 5
2. SELECT field1, field2, field3 [,……] FROM Table_Name WHERE ROWNUM = 1
第一条语句是不会返回任何记录的,因为在Oracle中只会执行上面步骤的1,2,3,5,这样ROWNUM的值将始终为1,始终不可能等于5. 而第2条语句只返回第一条记录,原因也就不需要我来详述了。
4. 当然还有MySql, SQL Server中该类语句的执行我就不细述了,如果有兴趣,你可以在论坛中讨论,当然如果你认为我写的有偏差请留言告知,不胜感谢!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-297633-1-1.html 上篇帖子: SQL Azure 入门教学(一):SQL Azure之初体验 下篇帖子: mssql server 2008 r2 sp2修复问题列表
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表