下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當前位置:軟件下載吧 > 數(shù)據(jù)庫 > MS_SQL > SQL開發(fā)知識:SqlServer使用公用表表達式CTE實現(xiàn)無限級樹形構建

SQL開發(fā)知識:SqlServer使用公用表表達式CTE實現(xiàn)無限級樹形構建

時間:2024-03-13 13:57作者:下載吧人氣:36

SQL Server 2005開始,我們可以直接通過CTE來支持遞歸查詢,CTE即公用表表達式

公用表表達式(CTE),是一個在查詢中定義的臨時命名結果集將在from子句中使用它。每個CTE僅被定義一次(但在其作用域內(nèi)可以被引用任意次),并且在該查詢生存期間將一直生存。可以使用CTE來執(zhí)行遞歸操作。

DECLARE @Level INT=3

;WITH cte_parent(CategoryID,CategoryName,ParentCategoryID,Level)
AS
(
SELECT category_id,category_name,parent_category_id,1 AS Level
FROM TianShenLogistic.dbo.ProductCategory WITH(NOLOCK)
WHERE category_id IN
(
SELECT category_id
FROM TianShenLogistic.dbo.ProductCategory
WHERE parent_category_id=0
)
UNION ALL
SELECT b.category_id,b.category_name,b.parent_category_id,a.Level+1 AS Level
FROM TianShenLogistic.dbo.ProductCategory b
INNER JOIN cte_parent a
ON a.CategoryID = b.parent_category_id
)

SELECT
CategoryID AS value,
CategoryName as label,
ParentCategoryID As parentId,
Level
FROM cte_parent WHERE Level <=@Level;
public static List<LogisticsCategoryTreeEntity> GetLogisticsCategoryByParent(int? level)
{
if (level < 1) return null;

var dataResult = CategoryDA.GetLogisticsCategoryByParent(level);
var firstlevel = dataResult.Where(d => d.level == 1).ToList();
BuildCategory(dataResult, firstlevel);
return firstlevel;
}

private static void BuildCategory(List<LogisticsCategoryTreeEntity> allCategoryList, List<LogisticsCategoryTreeEntity> categoryList)
{
foreach (var category in categoryList)
{
var subCategoryList = allCategoryList.Where(c => c.parentId == category.value).ToList();
if (subCategoryList.Count > 0)
{
if (category.children == null) category.children = new List<LogisticsCategoryTreeEntity>();
category.children.AddRange(subCategoryList);
BuildCategory(allCategoryList, category.children);
}
}
}

標簽MSSQL,SQLServer,技術文檔,數(shù)據(jù)庫,SQLSERVER

相關下載

查看所有評論+

網(wǎng)友評論

網(wǎng)友
您的評論需要經(jīng)過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 宅男66lu国产乱在线观看| 婷婷99视频精品全部在线观看| 亚洲色欲久久久综合网| 麻豆女神吴梦梦| 外国成人网在线观看免费视频| 久久亚洲精品国产亚洲老地址| 国产交换丝雨巅峰| 天堂√最新版中文在线天堂| 久久免费视频3| 欧美人与性动交α欧美精品图片| 又大又硬又黄的免费视频| 天天影视色香欲综合免费| 奇米影视77777| 久久亚洲国产精品五月天婷| 欧美精欧美乱码一二三四区| 可以看的黄色软件| 狠狠色噜噜狠狠狠狠69| 在线欧美精品国产综合五月| 中文字幕26页| 欧美在线黄色片| 全黄大全大色全免费大片| 韩国理论片中文字幕版电影| 国产精品美女自在线观看免费| 一女多男在疯狂伦交在线观看| 日本老熟老太hd| 亚洲国产一区二区三区| 琪琪女色窝窝777777| 四虎永久免费影院| 麻豆国产入口在线观看免费| 国产美女精品三级在线观看| 一本到卡二卡三卡免费高| 日本在线视频WWW鲁啊鲁| 亚洲乱人伦在线| 欧美视频免费在线| 免费超爽大片黄| 老师的圣水女主小说网| 国产成人亚洲综合a∨| 91一区二区视频| 天堂在线中文在线| 一区二区三区影院| 成熟女人特级毛片www免费|