asp学习网: 首页 >> asp与数据库 >> sql server教程 >> 一个Select出一个表中第N条记录的SQL代码

一个Select出一个表中第N条记录的SQL代码

一个Select出一个表中第N条记录的SQL代码

上周,被一位网友问到在SQL2000中,想选取一张表的第N条记录怎么写?(即如下语句s
elect ID,Name,Title from WebSite order by ID desc 如何改写以达到目的?)

我当时直接就给他回了:

select ID,Name,Title from WebSite where ID= N

最后这位老兄说如果ID是连续的话就可以,如果有记录删除的话,ID不连续了,就不行
了,至此才明白他的真正意思。想了一下,给出了如下答案:

-- select top 1 [ID],[Name,Title from WebSite

-- where not [ID] in (select top 11 [ID] from WebSite order by [ID] asc)
order by [ID] asc

Declare @strSql Varchar(200),@intTopN int

Set @intTopN = 11

Set @strSql = 'select top 1 [ID],[Name,Title from WebSite where not [ID] i
n (select top '+Cast(@intTopN As Varchar(10))+' [ID] from WebSite order
by [ID] asc) order by [ID] asc'

Print @strSql

Exec(@strSql)

做完之后,总感觉应该会有更好的解决方案,可又一时想不出来!将其放在这里,供各
位讨论,如有最佳方案也请网友们不吝赐教! from:asp学习网/title:一个Select出一个表中第N条记录的SQL代码/ time:2007-10-19 1:14:56

本文主题SQL

sql数据类型 查询中的数据类型

sql 多表查询简述

SQL子选择合并查询

SELECT查询中的计算COUNT AVG SUM max MIN

利用sql查询创建access数据表或者修改字段属性的参考

SQL:游标 原理和使用方法

asp与mysql的应用的乱码问题

SQL Server2000同步复制技术实现步骤

asp教程 ©2006-2007 aspxuexi.com | 关于站点 | 版权隐私 | 站内搜索
复制或者翻版 请于夜间进行