信息模式由一组视图组成,它们包含有关当前数据库里定义的对象的 信息。信息模式时 SQL 标准里定义的,因此可以认为是可以移植的, 并且是相对稳定的--和系统表不一样,系统表是 PostgreSQL 特有的,是在实现的基础上进行建模的。但信息模式视图不包含有关 PostgreSQL 特有的特性的信息; 你可以利用它查询有关系统表或者其它 PostgreSQL 相关的视图。
信息模式本身是一个叫 information_schema 的模式。 这个模式自动存在于所有数据库中。这个模式的所有者是数据库集群中的最初的数据库用户,并且这个用户天然旧拥有这个模式上的所有权限, 包括删除它的权限(不过这么干省下来的空间小的可怜)。
缺省的时候,信息模式不在模式搜索路径中,因此,你需要用全称来访问里面的所有对象。 因为信息模式里的一些对象的名字是可能在用户应用中出现的普通名字,所以, 如果你想把信息模式放在路径中的话,那你一定要小心。