动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   Asp → 阅读文章

 讨论 SELECT TOP N 问题

作者来源: 
阅读 3267 人次 , 2000-6-27 

    现在正在一家计算机公司兼职,开发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<=NM1:SELECT * FROM
     ( SELECT * FROM MYTABLE ORDER BY ORD_COL DESC) WHERE ROWNUM<=NM2:
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 MYTABLEWHERE  ROWID<=N
ORDER BY ORD_COL DESC;WRONG 2:(因为WHERE ROWNUM<=N 在ORDER BY 前执行)
SELECT * FROM MYTABLEWHERE  ROWNUM<=N ORDER BY ORD_COL DESC;3: DB2
用FETCH FIRST N ROWS ONLY M1: SELECT * FROM MYTABLEORDER BY ORD_COL DESC
FETCH FIRST N ROWS ONLYM2:没有找到,因为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  
 
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:global.asa文件总是不起作用?
· 下一篇:在Asp中使用存储过程
· 会员系统“找回密码”的制作方法
· 怎么用ASP实现分页(二)
· datagrid编辑、修改、删除、翻页例子
· 在select语句中使用top的一些小技巧
· 不用询问关闭一个独立的窗口代码


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077