中国开发网: 论坛: 程序员情感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
我的blog:http://szhaitao.blog.hexun.com & http://www.hoolee.com/user/haitao
--以上均为泛泛之谈--
不尽牛人滚滚来,无边硬伤纷纷现 人在江湖(出来的),哪能不挨刀(总归是要的)
网络对话,歧义纷生;你以为明白了对方的话,其实呢?

您所在的IP暂时不能使用低版本的QQ,请到:http://im.qq.com/下载安装最新版的QQ,感谢您对QQ的支持和使用

相关信息:


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