按照tp5的官方文档的说法, 必须这么做: 先执行一段sql代码

 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" ),
   "fields_name" ),
   "fields_type" ),
   "fields_length" BIGINT,
   "fields_not_null" ),
   "fields_default" ),
   "fields_comment" )
 );

 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_attrdef.adsrc 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;
           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 '获得表信息';

;

thinkphp5, 结合pgsql使用时, 要先运行这段sql代码的更多相关文章

  1. 用BSF + Beanshell使Java程序能够运行字符串形式的代码(转载)

    BSF(Bean Scripting Framework)最初是IBM Alpha工作组的项目,后来贡献给了Apache,BSF使Java能够更好的与各种流行脚本语言整合,实现不同语言之间的交互功能. ...

  2. 使用node成功安装完某插件typescript后,在使用时提示:tsc(或xxx)不是内部或外部命令,也不是可运行的程序或批处理文件

    具体出错情形: 使用npm安装typescript明明安装成功,但在使用时一直报错,报错语句为  tsc不是内部或外部命令,也不是可运行的程序或批处理文件 具体出错原因: node未正确安装,或相关环 ...

  3. MySQL 安装和启动服务,“本地计算机 上的 MySQL 服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止。”

    MySQL 安装和启动服务,以及遇到的问题 MySQL版本: mysql-5.7.13-winx64.zip (免安装,解压放到程序文件夹即可,比如 C:\Program Files\mysql-5. ...

  4. fstream对象重复使用时注意clear()的调用

    fstream对象重复使用时注意clear()的调用,否则会造成打开第二个文件失败.这是因为一个fstream对象对应磁盘上的一个文件,这种绑定关系在调用open()函数或者构造函数时指定,但有时我们 ...

  5. Eclipse和Android Studio中的DDMS使用时什么不同?

    http://www.jb51.net/softjc/454131.html Eclipse和Android Studio中的DDMS使用时什么不同? 相信很多经常开发Android应用的朋友应该都接 ...

  6. SSH hibernate 使用时最好添加访问数据库的编码

    SSH hibernate 使用时最好添加访问数据库的编码 如下所示:第13行为设置hibernate访问数据库的编码(&是&的转义序列) <!DOCTYPE hibernate ...

  7. Toolbar 和 CollapsingToolbarLayout一起使用时menu item无点击反应解决办法

    昨天一直在琢磨为什么Toolbar和CollapsingToolbarLayout一起使用时menu item无点击放应的原因,后来在stackoverflow上一条回答,说可能是Toolbar的背景 ...

  8. jqueryUI中datepicker的使用,解决与asp.net中的UpdatePanel联合使用时的失效问题

    1.jqueryUI的datepicker的使用 -->首先在jqueryUI官网上根据你的需要下载适合你系统主题的样式,jqueryUI主题下载地址: -->下载后的文件 jquery- ...

  9. 【原】无脑操作:IDEA使用时,提示"8080端口被占用"的解决

    1.问题描述:IDEA使用时,提示"8080端口被占用" Description:    The Tomcat connector configured to listen on ...

随机推荐

  1. Akka之BackoffSupervisor

    一.背景 最近在开发一个项目,项目的各模块之间是使用akka grpc传输音频帧的,并且各模块中的actor分别都进行了persist.本周在开发过程中遇到了一个bug,就是音频帧在通行一段时间后,整 ...

  2. Mac git 的使用

    1. mac 安装git brew install git 2.初使化 git config --global user.name "mygit" git config --glo ...

  3. perl learning

    Perl 中文教程 http://cn.perlmaven.com/perl-tutorial learning perl in about 2 hours 30 minutes http://qnt ...

  4. HTTP协议header头域

    HTTP(HyperTextTransferProtocol)是超文本传输协议的缩写,它用于传送WWW方式的数据,关于HTTP协议的详细内 容请参考RFC2616.HTTP协议采用了请求/响应模型.客 ...

  5. Android为什么方法数不能超过65535

    言归正传,来聊聊为什么方法数不能超过65535?搬上Dalvik工程师在SF上的回答,因为在Dalvik指令集里,调用方法的invoke-kind指令中,method reference index只 ...

  6. SQL 语句基础

    一 查询常量1. SELECT 学生编号, 学生姓名,性别 FROM tb_Student2. SELECT 学生姓名 AS 姓名, 性别 AS 学生性别 FROM tb_Student3. SELE ...

  7. 算法之美--2.2 Array

    2016-12-02    00:24:12 利用抽象数据类型实现Array:主要用C++模板实现数组类:体会一个完整的C++类的写法,能顺利写出来的人不多了,特别是对复制构造函数和重载= []运算, ...

  8. MetaQ对接SparkStreaming示例代码

    由于JavaReceiverInputDStream<String> lines = ssc.receiverStream(Receiver<T> receiver) 中 没有 ...

  9. java 几个线程池的理解

    http://www.cnblogs.com/dolphin0520/p/3932921.html 这个文章写的很好

  10. 二叉查找树BST----java实现

                                                                    二叉查找树BST----java实现 1.二叉查找树简单介绍 二叉查找树 ...