Rex

——生命不止,奋斗不息。
posts - 27, comments - 8, trackbacks - 0, articles - 0
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

关 于 查 询

Posted on 2007-11-23 13:02 W.R 阅读(100) 评论(0)  编辑  收藏
1.查询从第N条到第M条:
       在MSSQL中  可以用  方式1:
SELECT TOP m-n+1 * FROM TableA 
  
WHERE (id NOT IN 
    (
SELECT TOP n-1 id FROM   TableA)) 
id 为TableA表的关键字
        也可用方式2:在存储过程中新建一张临时表 取查询表的主键做字段
CREATE procedure pagination1
(
@pagesize int,  --页面大小,如每页存储20条记录
@pageindex int   --当前页码
)
as
set nocount on
begin
declare @indextable table(id int identity(1,1),nid int)  --定义表变量
declare @PageLowerBound int  --定义此页的底码
declare @PageUpperBound int  --定义此页的顶码
set @PageLowerBound=(@pageindex-1)*@pagesize
set @PageUpperBound=@PageLowerBound+@pagesize
set rowcount @PageUpperBound
insert into @indextable(nid) select gid from TGongwen where fariqi >dateadd(day,-365,getdate()) order by fariqi desc
select O.gid,O.mid,O.title,O.fadanwei,O.fariqi from TGongwen O,@indextable t where O.gid=t.nid
and t.id>@PageLowerBound and t.id<=@PageUpperBound order by t.id
end
set nocount off


借助临时表来达到你的目的。
个人推荐第1种方式。

另外  not in 与 not exists 在执行效率上是没有本质的区别的。

只有注册用户登录后才能发表评论。


网站导航: