zoukankan      html  css  js  c++  java
  • SqlServer 递归查询

    表:

    CREATE TABLE Category(

      ID      INT,

      NAME     INT,

      ParentID   INT

    向上递归:

     

    代码
    CREATE    FUNCTION [dbo].[GetRootCategoryID]
    /*
        Author:yanghh
        Date:2009-08-10
        des:得到某一类根结点
    */
    (
        
    @CategoryID INT
    )
    RETURNS @SubCategory TABLE(CategoryID INT,Level INT)
    AS
    BEGIN
        
    DECLARE @level    INT
        
    SET @level = 0
        
    INSERT INTO @SubCategory
        
    SELECT ID,@level FROM Category WHERE ID=@CategoryID
        
    WHILE @@ROWCOUNT >0
        
    BEGIN
            
    SET @level = @level+1
            
    INSERT INTO @SubCategory
            
    SELECT ParentId,@level FROM Category A, @SubCategory B 
                
    WHERE B.CategoryID = A.ID AND B.Level=@level-1
        
    END
        
    RETURN
    END

    向下递归:

    代码
    CREATE    FUNCTION [dbo].[GetChildCategoryID]
    /*
        Author:yanghh
        Date:2009-08-10
        des:得到某一类别子结点

    */
    (
        
    @CategoryID INT
    )
    RETURNS @SubCategory TABLE(CategoryID INT,Level INT)
    AS
    BEGIN
        
    DECLARE @level    INT
        
    SET @level = 0
        
    INSERT INTO @SubCategory
        
    SELECT ID,@level FROM CC_VOD_FilmCategory WHERE ID=@CategoryID
        
    WHILE @@ROWCOUNT >0
        
    BEGIN
            
    SET @level = @level+1
            
    INSERT INTO @SubCategory
            
    SELECT ParentId,@level FROM Category A, @SubCategory B 
                
    WHERE B.CategoryID = A.ParentID AND B.Level=@level-1
        
    END
        
    RETURN
    END
  • 相关阅读:
    CookieUtil.java
    观察者模式
    ELK日志分析系统
    Zookeeper安装配置及简单使用
    Zookeeper
    MBMD(MobileNet-based tracking by detection algorithm)作者答疑
    python代码迷之错误(ModuleNotFoundError: No module named 'caffe.proto')
    深度学习中易混概念小结
    Python爬虫小结
    VOT工具操作指南(踩过的坑)
  • 原文地址:https://www.cnblogs.com/BlueWoods/p/1681801.html
Copyright © 2011-2022 走看看