中国开发网: 论坛: 程序员情感CBD: 贴子 391836
haitao
现在使用表变量,不用建表、插入记录,直接一个sql就可以测试了
declare @tbinfo table (fid int ,fdata int)
insert @tbinfo values (1,1111)
insert @tbinfo values (2,2222)
insert @tbinfo values (3,3333)
insert @tbinfo values (4,4444)
insert @tbinfo values (5,5555)

declare @cid int
set @cid=1
--@cid==1,5 bad; 2,3,4 ok

select a.*,isnull(b.fprevid,-1) fprevid,isnull(c.fnextid,-2) fnextid
from (SELECT * FROM @tbInfo where fID=@cid ) a
left join (select top 1 @cid as fid,fid as fprevid from @tbinfo where fid<@cid order by fprevid desc) b on a.fid=b.fid
left join (select top 1 @cid as fid,fid as fnextid from @tbinfo where fid>@cid order by fnextid) c on a.fid=c.fid

相关信息:


欢迎光临本社区,您还没有登录,不能发贴子。请在 这里登录