通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏

 

qq,asp,php,jsp,xml,sql,.net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | q q 专栏 | 建站经验 | 在线工具 | 站长club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务
当前位置:首页>>在线服务>>疑难解答>>正文 新版上线![旧版]
注:打开慢时请稍等

select top n 问题

http://www.iyit.net  日期:2006-5-3 19:23:01  来源:  点击:
参加讨论】 hi, everyone:
本贴讨论select top n问题.
现在正在一家计算机公司兼职,开发asp应用. 在最近的一个商业项目里有这样一个需求:用户在查询时,只需要按照某(些)列排序后top 20的纪录. sql server 7很好地支持了top n 操作,但考虑到系统移植问题, 我又考虑在其他几个主流dbmss中如何实现. 鉴于只有db2 udb 7,oracle 8i,sql server 7,本贴仅讨论这三个dbms.
简单地说,top n问题就是:在select中,仅选择按照某(些)列排序后top n的纪录. 考虑到等值问题,又可以分为两种: 一是仅仅返回n条纪录(m 1), 二是还包括所有于第n条等值的纪录(m 2). 当然最内层的子查询也可以有其他的子句, 或者top n也可以应用在没有order by的情况下,这样更简单.

1. sql server 7: 用 top n (with ties)
m1:
select top n * from mytable order by ord_col;

m2:
select top n with ties * from mytable order by ord_col;
注: sql server 7提供了percent n with ties, access 中提供了top n,但含义是m 2.

2. oracle 8i: 用 rownum<=n
m1:
select * from
( select * from mytable order by ord_col desc)
where rownum<=n
m2:
select * from mytable where ord_col>=
(select min(ord_col) from
( select * from mytable order by ord_col desc)
where rownum<=n)
order by ord_col desc
注意以下两种错误用法:
wrong 1:
select * from mytable
where rowid<=n
order by ord_col desc;

wrong 2:(因为where rownum<=n 在order by 前执行)
select * from mytable
where rownum<=n
order by ord_col desc;

3: db2
用fetch first n rows only
m1:
select * from mytable
order by ord_col desc
fetch first n rows only
m2:
没有找到,因为db2不允许在from中嵌套有order by子句的子查询.

还不清楚oracle的m 2有没有更好的办法,以及其他的dbms如何实现top n操作,请其他朋友补充.
----------------------------------------------------------------------------------
各语句已经测试过, example:
create table mytable(mykey int, ord_col int);
insert into mytable values(1, 100);
insert into mytable values(2, 100);
insert into mytable values(3, 99);
insert into mytable values(4, 101);
insert into mytable values(5, 101);

fang 6/23/2000


编辑:黑鹰 [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:sql server 7.0 函数及sql语句相关问题
下一篇:select top n问题 (2)
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
最新更新 热点排行 推荐新闻
exeplorer.exe错误的问题的总结、解决
哪些数据库是免费的?                
如何实现mysql中的用户管理?         
在存储过程中使用use database       
怎样在vc、delphi中使用mysql(mysql o
快速安装windows操作系统独家秘籍
30秒清除windows系统所有垃圾
系统盘符错乱的解决方案
由windows远程桌面想到的复制粘贴问题
不输密码照样登陆操作系统
完美解决一个事件激活多个函数(2)
初学javascript之cookie篇(译)
javascript对象与数组参考大全
用javascript 实现的dual listbox
javascript版的日期输入控件
qq密码被盗怎么办!我教你找回密码
winrar将推出免费正版序列号!
轻易破解winrar,winzip密码
备份软件ghost使用教程
xp中重新安装或修复ie6的三种方法
让winrar汗颜的压缩软件uharc
ghost批处理命令用法详解
qb这样拿!免费获取qb方法剖析
如何控制我的电脑只允许登录我自己的q
qq2006 beta3隆重发布 实用功能一一奉
exeplorer.exe错误的问题的总结、解决
快速安装windows操作系统独家秘籍
30秒清除windows系统所有垃圾
系统盘符错乱的解决方案
由windows远程桌面想到的复制粘贴问题
不输密码照样登陆操作系统
windows下的虚拟主机设置全功略
windows操作系统完美维护技巧
ghost备份问题精彩解决方法集锦
菜鸟学电脑之端口基础知识
qq号码激活的常见问题及案例分析 
 友情链接
设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights © 2004-2006 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息