SQL递归查询示例

-- =============================================
-- Author:        zhaowei
-- Create date: 2012-7-23
-- Description:    获取指定分类下的产品(含子分类)
-- =============================================
ALTER PROCEDURE [dbo].[GetProductsByCategoryID]
    (
        @top int,
        @ProductCategoryID int
    )
AS
BEGIN
    SET NOCOUNT ON;
    with SCT(ElementID,[Name],ParentID,OrderNumber)
    as
    (
        select ElementID,[Name],ParentID,OrderNumber
        from Site_Category
        where ParentID=@ProductCategoryID
        union all
        select a.ElementID,a.[Name],a.ParentID,a.OrderNumber from Site_Category a
        inner join SCT b on a.ParentID=b.ElementID
    )
     
        select top(@top) * from Product where CategoryID in(
        select ElementID from SCT
        union all
        select ElementID from Site_Category where ElementID=@ProductCategoryID
    )   
END

 

posted @   skybirdzw  阅读(195)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示