T-SQL 选择某一记录的前后相关记录
比方有一商品表commodity
编号 名称 其他列...
1 a
2 b
3 c
4 x
5 t
6 a
7 b
如果给定 编号(id) 为 3 需要取 4条记录 ,那么应该返回 ID:1,2,4,5 四条记录
如果给定 id=2 那么返回 ID: 1,3,4,5
如果给定 id=7 那么返回 ID: 3,4,5,7
代码如下(SQL2000)
--------------------------------
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO
ALTER Proc Commodity_QueryRelative
@id int,
@num int =4
As
Declare @SQL nvarchar(2000)
Declare @highNum int
Declare @LowNum int
Declare @username nvarchar(50)
Set @SQL=''
Set @highNum=0
Set @LowNum=''
Set @username=''
Select @Username=Username From [Commodity] Where [Id]=@id
Select @highNum=Count(ID) From [Commodity] Where [Id]> @id And Username=@Username
Select @LowNum=Count(ID) From [Commodity] Where [Id]< @id And Username=@Username
Declare @margin int
Declare @halfNum int
Set @halfNum=@num/2
Set @margin =0
If @HighNum < @halfNum And @LowNum <@halfNum
Begin
Set @SQL='Select Top '+ cast(@halfNum as nvarchar) +' [ID], [Title], [Keys], [ClassID], [ClassIDPath], [ClassName], [ClassNamePath], [UserClassID], [UserClassName],[Img], [ThumImg], [AreaID], [AreaName], [Address], [Linkman], [UpdateTime],[AddTime]
From Commodity
Where Username='''+ @username + ''' And Id !=' + Cast(@id as nvarchar)
End
Else
Begin
Declare @LessNum int
Declare @largeNum int
Set @LessNum=0
Set @LargeNum=0
If @HighNum >=@halfNum And @LowNum >=@halfNum
Begin
Set @LessNum=@halfNum
Set @largeNum=@halfNum
End
If @HighNum >= @halfNum And @LowNum< @halfNum
Begin
Set @LessNum=@halfNum
Set @largeNum=@num-@LowNum
End
If @HighNum < @halfNum And @LowNum >= @halfNum
Begin
Set @LessNum=@num-@HighNum
Set @largeNum=@halfNum
End
Set @SQL='Select * From
(
Select Top '+ cast(@LessNum as nvarchar) +' [ID], [Title], [Keys], [ClassID], [ClassIDPath], [ClassName], [ClassNamePath], [UserClassID], [UserClassName],[Img], [ThumImg], [AreaID], [AreaName], [Address], [Linkman], [UpdateTime],[AddTime]
From Commodity
Where Username='''+ @username + ''' And Id <' + Cast(@id as nvarchar) +' Order By ID DESC
) as t1
Union
Select * From
( Select Top '+ cast(@LargeNum as nvarchar) +' [ID], [Title], [Keys], [ClassID], [ClassIDPath], [ClassName], [ClassNamePath], [UserClassID], [UserClassName],[Img], [ThumImg], [AreaID], [AreaName], [Address], [Linkman], [UpdateTime],[AddTime]
From Commodity
Where Username='''+ @username + ''' And Id >' + Cast(@id as nvarchar) +'
) as T2 '
End
Exec(@SQL)
GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述