簡體   English   中英

PL / pgsql正確在查詢中動態轉換regclass的方法

[英]PL/pgsql Correct way to cast regclass dynamically in query

我有一個功能,該功能將遍歷一個表,然后遍歷從externalloop的每個表繼承的所有表。 我發現了一個很棒的功能來查找從父表繼承的表。 我的問題是,如何動態更改表名以查找所有父級? 因此'shopmaster.pb':: regclass類似於'shopmaster。'|| i.tablename :: regClass。

CREATE OR REPLACE FUNCTION shopmaster.cascade_filters()
RETURNS jsonb AS $$
DECLARE
    i record;
    k shopmaster."catalog_filters";
BEGIN
    DELETE FROM shopmaster.catalog_filters WHERE isparent=false;
    FOR i IN SELECT shopmaster.catalog.catalogid,columnname,columntype,columnnvalues,
        tablename FROM shopmaster.catalog_filters INNER JOIN catalog ON 
        (catalog_filters.catalogid=catalog.catalogid) WHERE isparent=true LOOP
        FOR k IN  
        WITH RECURSIVE inh AS (
            SELECT i.inhrelid FROM pg_catalog.pg_inherits i WHERE inhparent=
            'shopmaster.pb'::regclass
            UNION
            SELECT i.inhrelid FROM inh INNER JOIN pg_catalog.pg_inherits i ON
            (inh.inhrelid = i.inhparent)
        )
        SELECT pg_namespace.nspname, pg_class.relname 
            FROM inh 
            INNER JOIN pg_catalog.pg_class ON (inh.inhrelid=pg_class.oid) 
            INNER JOIN pg_catalog.pg_namespace ON
            (pg_class.relnamespace=pg_namespace.oid) LOOP

        END LOOP;
    END LOOP;
END;
$$ LANGUAGE plpgsql;

事實證明,有一種簡單的方法。 執行子表達式以concat或執行其他操作以獲取表標識符,然后將其強制轉換為:: regclass。 例如('shopmaster。'|| i.tablename):: regclass

CREATE OR REPLACE FUNCTION shopmaster.cascade_filters()
RETURNS jsonb AS $$
DECLARE
    i record;
    k record;
BEGIN
    DELETE FROM shopmaster.catalog_filters WHERE isparent=false;
    FOR i IN SELECT shopmaster.catalog.catalogid,columnname,columntype,
        columnnvalues,tablename
        FROM shopmaster.catalog_filters INNER JOIN shopmaster.catalog ON
        (catalog_filters.catalogid=catalog.catalogid) WHERE isparent=true LOOP
        FOR k IN
        WITH RECURSIVE inh AS (
            SELECT ih.inhrelid FROM pg_catalog.pg_inherits ih WHERE inhparent=
            ('shopmaster.'||i.tablename)::regclass
            UNION
            SELECT ih.inhrelid FROM inh INNER JOIN pg_catalog.pg_inherits ih ON
            (inh.inhrelid = ih.inhparent)
        )
        SELECT pg_namespace.nspname, pg_class.relname,
            shopmaster.catalog.catalogid
            FROM inh
            INNER JOIN pg_catalog.pg_class ON (inh.inhrelid=pg_class.oid)
            INNER JOIN pg_catalog.pg_namespace ON
            (pg_class.relnamespace=pg_namespace.oid)
            INNER JOIN shopmaster.catalog ON
            (pg_class.relname=shopmaster.catalog.tablename) LOOP
            EXECUTE 'INSERT INTO shopmaster.catalog_filters (catalogid,'
                ||'columnname,columntype,columnnvalues,isparent,owner) '
                ||'VALUES($1,$2,$3,$4,false,$5)' USING k.catalogid,i.columnname,
                i.columntype,i.columnnvalues,i.catalogid;
        END LOOP;
    END LOOP;
    RETURN jsonb_build_object('ok',true);
END;
$$ LANGUAGE plpgsql;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM