加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在PostgreSQL中显示表结构和表列表

发布时间:2020-12-13 16:19:34 所属栏目:百科 来源:网络整理
导读:参见英文答案 PostgreSQL “DESCRIBE TABLE”18个 我曾在几个以前的项目中使用过MySQL.但现在有了 决定改用PostgreSQL.不是说版本8也适用于此, 我在工作中遇到的其他操作系统. 但是,有两个最有用的命令似乎丢失了: 显示表格 DESCRIBE表 因为我的原型数据库
参见英文答案 > PostgreSQL “DESCRIBE TABLE”18个
我曾在几个以前的项目中使用过MySQL.但现在有了
决定改用PostgreSQL.不是说版本8也适用于此,
我在工作中遇到的其他操作系统.

但是,有两个最有用的命令似乎丢失了:

>显示表格
> DESCRIBE表

因为我的原型数据库在家里的NetBSD服务器上,而我的
等待“基于”的数据正在起作用,因此我必须通过连接
Perl / DBI和XML-RPC(不是psql,唉).这里的IT部门只是说,“使用
MS-Access“,所以没有帮助.

当我处于初始阶段时,我需要一个信息丰富的方式来犯错误
当我尝试不同的方式来构建这个东西时,看看是什么.
为此,我一直依赖MySQL的上述两个.

我无法相信PostgreSQL没有办法告诉我是什么
当前DB的表结构是通过远程执行的简单SQL查询实现的.

当然必须有.但我似乎无法从这对夫妇身上找到答案
我有的书.我挖出来的只是一些非常蹩脚的黑客来获取专栏名称
通过执行“WHERE 1!= 1”或其他一些已知的表名
这样就不会返回实际的行.不是很有用,那个.
当然,我已经错过了某个地方.

请赐教.请注意,PostgreSQL-ish SQL是什么
查询一个用于探索给定DB的表结构?什么是
PostgreSQL翻译为“SHOW TABLES”和“DESCRIBE table”?

按照 Documentation
SELECT
    table_schema || '.' || table_name as show_tables
FROM
    information_schema.tables
WHERE
    table_type = 'BASE TABLE'
AND
    table_schema NOT IN ('pg_catalog','information_schema');

为了更方便,使它成为一种功能

create or replace function show_tables() returns SETOF text as $$
SELECT
    table_schema || '.' || table_name as show_tables
FROM
    information_schema.tables
WHERE
    table_type = 'BASE TABLE'
AND
    table_schema NOT IN ('pg_catalog','information_schema');
$$
language sql;

所以我们可以使用表格

select show_tables()

对于表格说明

select column_name,data_type,character_maximum_length
 from INFORMATION_SCHEMA.COLUMNS where table_name ='table_name';

作为一个功能

create or replace function describe_table(tbl_name text) returns table(column_name   
varchar,data_type varchar,character_maximum_length int) as $$
select column_name,character_maximum_length
from INFORMATION_SCHEMA.COLUMNS where table_name = $1;
$$
language 'sql';

select  *  from describe_table('a_table_name');

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读