SqlServer2005 查询 第五讲 top
今天我们来说sql命令中得参数top
top
- top【 最前面若干个记录,专属于SqlServer2005的语法,不可移植到其他库。oracle中是用rownum<6来实现输出前5行记录。】
下面我们引入一个题目来分析一下这个top参数
请查询在scott这个库中的emp表的前三条记录
select top 3 * from emp // --这里的top 3是指前3条记录,*是指所有字段的值
// -- 所以在执行的时候首先会找到emp表,然后开始查询表中的
//-- 第一条记录,发现符合top 3 这个参数的特质,于是就输出
//-- 这条记录的所有字段的值
//--然后开始查询第二条记录......一直这样查询下去,直到查询
//--到第四条记录的时候
//--发现不符合这个top 3这个参数的特征,于是
//--就,不进行输出了,也不在进行下一条记录的查询了
下面我们来看一下上面这一条sql命令所执行的结果
我们可以发现只输出了前emp表的前三条记录
- top还可以和百分比的结合的来使用。
例如
select top 15 percent * from emp //--这里我们可以把top 15 percent作为一个整体
//-- 表示输出emp表的前%15个记录
//-- 注意:如果表的前%15不是一个整数的话
// -- 就进位
//-- 假如emp表有14条,那么14*%15=2.1。
//-- 则就会输出前三条记录的所有字段的值
//-- 执行的顺序的话,可以参照上一条sal命令的
//注释
下面我们来看一下上面这一条sql命令所执行的结果
我们会发现,也只输出了emp表前面的三条记录
- 注意下面这条sql命令是错误的
select top 2 from emp //之所以这条命令是错误的,是因为当,查询到前面两条记录的时
//侯,这条sql命令却并没有有告诉你应该查询那个字段的值
//或者那几个字段的值,或者所有字段的值
我们再来分析一个题目
- --把工资在1500到3000(包括1500 到3000)员工的工资最高前4个按降序输出
select top 4 * (4)
from emp (1)
where sal between 1500 and 3000 (2)
order by sal desc(3)
//-- order by 是排序的意思,以后我会详细的说,desc是降序的意思,默认情况下是升序的意思。
//--我们来看这个命令的执行情况
//--首先会执行(1)步找到emp这个表,然后查询第一条记录
//--然后执行第(2)步where后面的语句,对原始的数据进行过滤
// --然后会执行(3)步,按照sal这个字段进行降序排序。
//--注意这个第(3)步这个sql命令不好理解,我认为,在这个sql命令的底层中应该用了某种算法。
//-- 当第一次执行到order by sal desc的时候,他应该就能遍历整个emp表然后按照sal这个字段的值降序。
//-- 然后就会执行最后的第(4)步
下面我们来看一下上面这一条sql命令所执行的结果
我们可以发现输出的是4条记录,sal这个字段的值都是在1500到3000这个范围,并且这个字段的值是降序的
今天的这一讲就到这里,下一讲我们来讲 null参数
***如果你们还有什么不懂的,可以加我qq485536603
SqlServer2005 查询 第五讲 top的更多相关文章
- SQL分页查询,纯Top方式和row_number()解析函数的使用及区别
听同事分享几种数据库的分页查询,自己感觉,还是需要整理一下MS SqlSever的分页查询的. Sql Sever 2005之前版本: select top 页大小 * from 表名 where i ...
- 查询分页-----强势top
查询分页:语句1性能提升10倍多,仅仅是由于多了个topkeyword,非常不理解啊!!!! 1.查询时间1s内,r_object_id主键 select top 100 * from ( sele ...
- elasticsearch 分页查询实现方案——Top K+归并排序
elasticsearch 分页查询实现方案 1. from+size 实现分页 from表示从第几行开始,size表示查询多少条文档.from默认为0,size默认为10,注意:size的大小不能超 ...
- SqlServer2005 查询 第四讲 in
今天我们来说sql中的命令参数in in --in用于查询某个字段的指定的值的记录信息 注意一下:--对或(or)取反是并且(and),对并且(and)取反是或(or 数据库中不等于表示有两种:!= ...
- SqlServer2005 查询 第三讲 between
在数据库的查询中最重要的是要知道命令的顺序,因为在sql命令中有许多的参数,例如distinct,top,in,order by,group by.......如果你不能理解什么时候该执行什么的话,很 ...
- SqlServer2005 查询 第一讲 计算列
数据库查询[最重要且在数据库中难度最大] 声明一下我这里用的数据库样例是郝斌老师的(scott库) 我尽最大努力把复杂的问题简单化,方便理解,希望我写的东西能够帮助到你们 有些复杂的东西我我用自己的方 ...
- Oracle 查询类似 select top 的用法
--查询前10条数据select * from MID_EHR_STAFF where rownum<10;--查询第5~10条的记录,minus(减)select * from MID_EHR ...
- SqlServer2005 查询 第七讲 order by
今天我们来讲sql命令中的参数order by的用法 order by order by:可以理解成[以某个字段排序] order by a,b // a和b都按升序 order by a,b des ...
- SqlServer2005 查询 第二讲 distinct
今天我们来说distinct关键字的用法. distinct - distinct:我们可以这样理解成[过滤重复值] - select distinct deptno from emp // -- 首 ...
随机推荐
- 马蜂窝 IM 移动端架构的从 0 到 1
(马蜂窝技术原创内容,公众号 ID:mfwtech) 移动互联网技术改变了旅游的世界,这个领域过去沉重的信息分销成本被大大降低.用户与服务供应商之间.用户与用户之间的沟通路径逐渐打通,沟通的场景也在不 ...
- API---文件操作
CreateFile() 介绍: 功能:打开或创建以下对象,并返回可访问的句柄: 控制台,通信资源,目录(只读打开),磁盘驱动器,文件,邮槽,管道. 函数原型:HANDLE CreateFile ( ...
- 【前端词典】几个有益的 CSS 小知识
今天偷个懒,不长篇大论,分享几个你可能不知道的 CSS 小知识. 样式的顺序 CSS 代码: HTML 代码: 记得之前这是一道比较火的 CSS 考题,当时好像是有不少的人答错(30% 以上) ...
- ThinkPHP5 远程命令执行漏洞分析
本文首发自安全脉搏,转载请注明出处. 前言 ThinkPHP官方最近修复了一个严重的远程代码执行漏洞.这个主要漏洞原因是由于框架对控制器名没有进行足够的校验导致在没有开启强制路由的情况下可以构造恶意语 ...
- libevent::bufferevent
#include <cstdio> #include <netinet/in.h> #include <sys/socket.h> #include <fcn ...
- Arduino学习笔记④ 经典按键实验
1.前言 我们讲了数字IO口介绍以及做了流水灯演示(主要用到IO口的输出功能),这节课我们讲解一下IO口的输入功能,说到输入功能,最经典的例子莫过于按键实验.废话少说,赶紧上车. 2.实验材料 ...
- [AHOI2002]哈利·波特与魔法石
这道题比较简单,就是一个最短路(SSSP).数据水,用Floyd即可AC.这里用了Dijkstra. #include <iostream> #include <cstdio> ...
- 【阿里云IoT+YF3300】7.物联网设备表达式运算
很多时候从设备采集的数据并不能直接使用,还需要进行处理一下.如果采用脚本处理,有点太复杂了,而采用表达式运算,则很方便地解决了此类问题. 一. 设备连接 运行环境搭建:Win7系统请下载相关的设备驱 ...
- jhipster入门
环境: 阿里云linux /////////////////////////////////////////////////////////////////////yum install java-1 ...
- 微信小程序中的canvas基础应用
学了东西还是要记录一下,刚入职的小萌新啊,运气好分到一个项目不是很急的组原以为时间多了可以多学一些东西,但是发现好像不知道从哪里开始下手,我太南了.... 看旁边的实习生同事一直在搞canvas,自己 ...