狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQL常用算法-遞歸表達(dá)式

admin
2024年3月30日 12:51 本文熱度 1320

語法函數(shù)

  • with as

    with as 在之前的章節(jié)中已經(jīng)用到,但是當(dāng)時(shí)只是用于創(chuàng)建臨時(shí)表使用,更大的作用在于組合成為遞歸表達(dá)式,分解層級(jí)。

常見場景

  一、制造業(yè)中,BOM是所有成本分析的底層,BOM表通常由自身ID,父級(jí)ID等元素構(gòu)成的層級(jí)表,通常我們需要獲得所有的末級(jí)元素,用于計(jì)算整體的材料費(fèi)用等

二、對(duì)于權(quán)限分配表,部門主數(shù)據(jù)也為帶有層級(jí)關(guān)系的層級(jí)表,通常我們需要對(duì)已知的部門查詢他的最上級(jí)部門,以此確認(rèn)權(quán)限

在上面兩種常見當(dāng)中,數(shù)據(jù)結(jié)構(gòu)都是以自身/上級(jí)的ID層級(jí)關(guān)系體現(xiàn),無論是通過頂層查詢底層還是通過底層查詢頂層,使用with as遞歸表達(dá)式都能輕松獲取我們所需要的數(shù)據(jù)。

示例


1.已知用戶部門,查詢他的最上級(jí)部門

WITH RECURSIVE DepartmentHierarchy AS (

    SELECT

        dept_id,

        parent_dept_id,

        0 AS level

    FROM

        departments

    WHERE

        dept_id = :input_dept_id  -- 指定要查詢的部門ID

    UNION ALL

    SELECT

        d.dept_id,

        d.parent_dept_id,

        dh.level + 1

    FROM

        departments d

    INNER JOIN

        DepartmentHierarchy dh ON d.dept_id = dh.parent_dept_id

)

SELECT

    dept_id,

    parent_dept_id

FROM

    DepartmentHierarchy

WHERE

    level = (SELECT MAX(level) FROM DepartmentHierarchy);

2.已知產(chǎn)品編碼,獲得所有最下級(jí)材料

WITH RECURSIVE ProductMaterials AS (
    SELECT
        product_id,
        material_id,
        1 AS level
    FROM
        bom_table
    WHERE
        parent_material_id IS NULL  -- 找到最上級(jí)產(chǎn)品

    UNION ALL


    SELECT
        b.product_id,
        b.material_id,
        pm.level + 1
    FROM
        bom_table b
    INNER JOIN
        ProductMaterials pm ON b.parent_material_id = pm.material_id)
SELECT DISTINCT
    product_id,
    material_id
FROM
    ProductMaterials
WHERE
    (product_id, level) IN (
        SELECT
            product_id,
            MAX(level) AS max_level
        FROM
            ProductMaterials
        GROUP BY
            product_id
    );

該文章在 2024/3/30 12:51:21 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved