PL / pgsql正确在查询中动态转换regclass的方法

时间:2018-07-25 13:54:32

标签: postgresql plpgsql

我有一个函数,该函数将遍历一个表,然后遍历从externalloop继承自每个表的所有表。我找到了great function来查找从父表继承的表。我的问题是,如何动态更改表名以查找所有父级?因此'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;

1 个答案:

答案 0 :(得分:0)

结果是有一种简单的方法。执行子表达式以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;