有时候为了方便sql语句的对比和查询,我们可以使用declare来定义变量 上下篇的问题

--定义一些参数
declare @nodeId int,@ekid int ,@ecid int,@eid int,@pid int
set @nodeId= 1
set @ekid = 7
set @ecid = 2
set @eid = 194
set @pid = 612

--列表
SELECT * FROM 
(
    SELECT *,ROW_NUMBER() OVER(ORDER BY ReleaseTime DESC) AS rowNum  FROM dbo.ViewExamProjectDetail 
    WHERE Status = 1 AND nodeid = @nodeId AND EKID = @ekid AND ECID = @ecid and eid=@eid
) AS t
WHERE t.rowNum BETWEEN 1 AND 100 


--上一篇
SELECT TOP 1 * FROM 
(
    SELECT *,ROW_NUMBER() OVER(ORDER BY ReleaseTime ASC) AS rowNum  FROM dbo.ViewExamProjectDetail 
    WHERE Status = 1 AND nodeid = @nodeId AND EKID = @ekid AND ECID = @ecid and eid=@eid 
) AS t WHERE t.ID>@pid


--下一篇
SELECT TOP 1 * FROM 
(
    SELECT *,ROW_NUMBER() OVER(ORDER BY ReleaseTime DESC) AS rowNum  FROM dbo.ViewExamProjectDetail 
    WHERE Status = 1 AND nodeid = @nodeId AND EKID = @ekid AND ECID = @ecid and eid=@eid
) AS t WHERE t.ID < @pid

 

posted @ 2016-11-25 11:24  麦田HH  阅读(1272)  评论(0编辑  收藏  举报