thinkphp读取PDSQL报错SQLSTATE[42883]: Undefined function: 7 ERROR: function table_msg(unknown) does not exist

169

CREATE OR REPLACE FUNCTION pgsql_type(a_type varchar) RETURNS varchar AS

$BODY$

DECLARE

     v_type varchar;

BEGIN

     IF a_type='int8' THEN

          v_type:='bigint';

     ELSIF a_type='int4' THEN

          v_type:='integer';

     ELSIF a_type='int2' THEN

          v_type:='smallint';

     ELSIF a_type='bpchar' THEN

          v_type:='char';

     ELSE

          v_type:=a_type;

     END IF;

     RETURN v_type;

END;

$BODY$

LANGUAGE PLPGSQL;

 

CREATE TYPE "public"."tablestruct" AS (

  "fields_key_name" varchar(100),

  "fields_name" VARCHAR(200),

  "fields_type" VARCHAR(20),

  "fields_length" BIGINT,

  "fields_not_null" VARCHAR(10),

  "fields_default" VARCHAR(500),

  "fields_comment" VARCHAR(1000)

);

 

CREATE OR REPLACE FUNCTION "public"."table_msg" (a_schema_name varchar, a_table_name varchar) RETURNS SETOF "public"."tablestruct" AS

$body$

DECLARE

    v_ret tablestruct;

    v_oid oid;

    v_sql varchar;

    v_rec RECORD;

    v_key varchar;

BEGIN

    SELECT

        pg_class.oid  INTO v_oid

    FROM

        pg_class

            INNER JOIN pg_namespace ON (pg_class.relnamespace = pg_namespace.oid AND lower(pg_namespace.nspname) = a_schema_name)

    WHERE

            pg_class.relname=a_table_name;

    IF NOT FOUND THEN

        RETURN;

    END IF;

 

    v_sql='

     SELECT

           pg_attribute.attname AS fields_name,

           pg_attribute.attnum AS fields_index,

           pgsql_type(pg_type.typname::varchar) AS fields_type,

           pg_attribute.atttypmod-4 as fields_length,

           CASE WHEN pg_attribute.attnotnull  THEN ''not null''

           ELSE ''''

           END AS fields_not_null,

           pg_get_expr(pg_attrdef.adbin, pg_attribute.attrelid) AS fields_default,

           pg_description.description AS fields_comment

     FROM

           pg_attribute

           INNER JOIN pg_class  ON pg_attribute.attrelid = pg_class.oid

           INNER JOIN pg_type   ON pg_attribute.atttypid = pg_type.oid

           LEFT OUTER JOIN pg_attrdef ON pg_attrdef.adrelid = pg_class.oid AND pg_attrdef.adnum = pg_attribute.attnum

           LEFT OUTER JOIN pg_description ON pg_description.objoid = pg_class.oid AND pg_description.objsubid = pg_attribute.attnum

     WHERE

           pg_attribute.attnum > 0

           AND attisdropped <> ''t''

           AND pg_class.oid = ' || v_oid || '

     ORDER BY pg_attribute.attnum' ;

 

    FOR v_rec IN EXECUTE v_sql LOOP

            v_ret.fields_name=v_rec.fields_name;

            v_ret.fields_type=v_rec.fields_type;

            IF v_rec.fields_length > 0 THEN

                v_ret.fields_length:=v_rec.fields_length;

            ELSE

                v_ret.fields_length:=NULL;

            END IF;

            v_ret.fields_not_null=v_rec.fields_not_null;

            v_ret.fields_default=v_rec.fields_default;

            v_ret.fields_comment=v_rec.fields_comment;

            SELECT constraint_name INTO v_key FROM information_schema.key_column_usage WHERE table_schema=a_schema_name AND table_name=a_table_name AND column_name=v_rec.fields_name;

            IF FOUND THEN

                v_ret.fields_key_name=v_key;

            ELSE

                v_ret.fields_key_name='';

            END IF;

            RETURN NEXT v_ret;

        END LOOP;

    RETURN ;

END;

$body$

    LANGUAGE 'plpgsql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;

 

COMMENT ON FUNCTION "public"."table_msg"(a_schema_name varchar, a_table_name varchar)

    IS '获得表信息';

 

---重载一个函数

CREATE OR REPLACE FUNCTION "public"."table_msg" (a_table_name varchar) RETURNS SETOF "public"."tablestruct" AS

$body$

DECLARE

    v_ret tablestruct;

BEGIN

    FOR v_ret IN SELECT * FROM table_msg('public',a_table_name) LOOP

            RETURN NEXT v_ret;

        END LOOP;

    RETURN;

END;

$body$

    LANGUAGE 'plpgsql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;

 

COMMENT ON FUNCTION "public"."table_msg"(a_table_name varchar)

    IS '获得表信息';


无人货架批量大规模上架商品解决方案

架构设计之初未考虑到业务需要批量上架商品,几万个逐一生成货架商品需要耗费大量人力,而货架商品的结构数量都一样。...

物业小区无人销售智能货架方案

小区无人值守货架销售的建设方案,从三个方面阐述货架集成建设,投入使用,系统管理。...

厨余收运管理系统迭代开发,回收系统优化升级

完成基础数据开发,试运行一段时间后,在数据沉淀的基础上对数据进行挖掘,对业务处理进行优化升级。...

餐厨油脂再生资源收运回收管理系统方案

通过互联网+改变餐厨收运回收传统工作方式,移动手机助力系统提供工作效率、’管理效率,数据电子化打造收运大数据建设。...

医馆诊所管理系统

实现中医馆中诊所,理疗的业务处理,分为小程序用户端,医生端,管理端,PC管理端,PC服务台,PC医生端...

thinkphp8安装VIEW,多应用,验证码

官方THKPHP8默认只有单应用一个控制器,其他插件可按需安装,通常需要VIEW和多应用...

sqlserver中的nvarchar和varchar的区别

数据库表中nvarchar和varchar都可以用来表示字符的存储类型。...

微信接口开发返回码一览表

返回错误码对照表...

高德地图mark按类型批次显示不同的颜色

大量数据点显示在地图上,通常使用海量点的API展示,通过建立多个海量点达到按分类显示不同颜色的mark,看起来更直观...

餐厨垃圾收运小程序需要什么条件

建立一个小程序的硬件设施需要服务器,域名,若干个邮箱...