WEB开发网
开发学院数据库MSSQL Server 一个Select出一个表中第N条记录的Sql代码 阅读

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

 2007-11-11 12:44:38 来源:WEB开发网   
核心提示:上周﹐被一位网友问到在sql2000中,想选取一张表的第N条记录怎麽写?(即如下语句select ID,Name,Title from WebSite order by ID desc 如何改写以达到目的)我当时直接就给他回select ID,Name,Title from WebSite where ID= N最后这

上周﹐被一位网友问到在sql2000中,想选取一张表的第N条记录怎麽写?(即如下语句select 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] in (select top  '+Cast(@intTopN  As Varchar(10))+'  [ID] from  WebSite order by [ID] asc)  order by [ID] asc'
Print @strSql
Exec(@strSql)

做完之后﹐总感觉应该会有更好的解决方案﹐可又一时想不出来!将其放在这里﹐供各位讨论拍砖﹐如有最佳方案也请网友们不吝指教!
http://www.cnblogs.com/jinliangliu/archive/2006/09/11/501007.html

Tags:一个 Select 一个

编辑录入:coldstar [复制链接] [打 印]
赞助商链接