Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 查询  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702656
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

sql如何返回第三或从第三条记录开始返回(分页问题)?

作者:cg1  摘自:access911.net  :cg1  更新日期:2003-2-9  浏览人次:

 

问题:

如何用sql返回第三条或者第三条记录开始返回?
从数据库中的表中从第三条记录开始取,那么select该怎么写呢?

 


回答:


select * from table_name where id_field not in (select top 3 id_field from table_name)

注意,其实就是把 select top 语句写两遍,第二遍包含了第一遍,然后把是第一遍中的记录用not in剔除就可以了,所以两个where都必须包含相同的外加条件。

asp 中经常用来写 pageno 的程序,因为直接用ado的pagesize如果遇上几十万数据,用pagesize就完蛋喽。

关于 not in 语句速度比较慢,某人提示将not in改为

select table2.* from table2 left join table1 on table2.key=table1.key where (able1.key is null)

返回第3条记录用:
select top 1 * from (SELECT top 3 a.编号 FROM a order by 编号) as b order by 编号 desc

如果用来进行分页,返回第100-150条记录,可以用
select top 50 * from (SELECT top 150 a.编号 FROM a order by 编号) as b order by 编号 desc

以下是 SQL SERVER 2000 T-SQL 分页代码

--------------------------
-- 分页代码

IF EXISTS (SELECT name 
       FROM   sysobjects 
       WHERE  name = N'p_GetTopic' 
       AND       type = 'P')
    DROP PROCEDURE p_GetTopic
GO

CREATE PROCEDURE p_GetTopic 
    @PageSize    int =15,
    @CurPage    int =1,
    @OrderBy    varchar(50) = 'desc'
    
AS
    declare @sql varchar(4000)
    --declare @intCount int
    --select @intCount = count(*) from t_Issue
    
    if LOWER(@OrderBy) = 'asc'
    begin
        select @sql=    'select ti.*,
                    tu.username,
                    tu.usernickname,
                    tu.ranknum,
                    tu.credit,
                    tr.roomname
                from    (select top ' + cast(@PageSize as varchar(20)) + ' * from t_issue 
                    where topicid > isnull((select max(topicid) from (select top ' + cast((@PageSize * (@CurPage -1) ) as varchar(20)) + ' * from t_Issue order by topicid ) a),0)  
                    order by topicid) ti
                left join t_user tu on ti.postuserid = tu.userid 
                left join t_room tr on ti.roomid = tr.roomid
                order by ti.topicid
                '
    end
    else
    begin
        select @sql=    'select ti.*,
                    tu.username,
                    tu.usernickname,
                    tu.ranknum,
                    tu.credit,
                    tr.roomname
                from    (select top ' + cast(@PageSize as varchar(20)) + ' * from t_issue 
                    where topicid < isnull((select min(topicid) from (select top ' + cast((@PageSize * (@CurPage -1) ) as varchar(20)) + ' * from t_Issue order by topicid desc) a),99999999)  
                    order by topicid desc) ti
                left join t_user tu on ti.postuserid = tu.userid 
                left join t_room tr on ti.roomid = tr.roomid
                order by ti.topicid desc
                '
        
    end
    
    execute(@sql)
    
    select count(*) as RecordCount from t_issue
GO

-- =============================================
-- example to execute the store procedure
-- =============================================
EXECUTE p_GetTopic 233,1
GO



 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     ASP分页问题代码
     ASP分页代码,已经写成类了,值得参考
     打印再添一例,自动分页
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利