4

我有一个包含 4 列的 PostgreSQL 数据库表 - 标记为 column_a、column_b 等。我想用一个简单的选择查询来查询这个表:

select * from table_name;

我得到了一些结果,如下所示:

column_a | column_b
---------+---------
'a value'|'b_value'

但是当我使用这个查询时:

select * from schema_name.table_name;

我得到了完整的结果:

column_a | column_b | column_c | column_d
---------+----------+----------+---------
'a value'|'b value' |'c value' |'d_value' 

cd并在以后创建初始表后添加。我的问题是:当模式名称被排除在选择查询之外时,为什么数据库会忽略后面的列?

4

1 回答 1

5

在 Postgres 的数据库中,表名不是唯一的。在不同的模式中可以有任意数量的名为“table_name”的表 - 包括临时模式,除非您在search_path. 显然,有多个名为table_name. 您必须了解 的作用search_path才能正确解释:

第一个表存在于schema_name您之前的模式中search_path(或schema_name根本没有列出)。所以不合格的表名被解析为这个表(或视图)。检查您当前角色在数据库中可以访问的名为“table_name”的表的列表:

SELECT *
FROM   information_schema.tables 
WHERE  table_name = 'table_name';

视图只是RULE内部附加的特殊表。它们可以起到与常规表相同的作用,并包含在上述查询中。细节:

于 2015-05-12T00:09:09.533 回答