遗忘海岸

江湖程序员 -Feiph(LM战士)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

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

 

posted on   遗忘海岸  阅读(438)  评论(0编辑  收藏  举报

编辑推荐:
· 如何编写易于单元测试的代码
· 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的设计模式综述
点击右上角即可分享
微信分享提示