受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

50.30. pg_largeobject #

目录pg_largeobject保存构成大对象的数据。一个大对象在被创建时会被分配一个OID。每个大对象被分解成段或,以便小到可以被方便地作为行存储在pg_largeobject中。每页中的数据量被定义为LOBLKSIZE(目前是BLCKSZ/4或是2 kB)。

PostgreSQL 9.0 之前,大对象没有相关的权限结构。因此,pg_largeobject曾是公开可读的,并且可以用来获得系统中所有大对象的 OID(和内容)。但现在已经不是这样了;可使用pg_largeobject_metadata来获得大对象 OID 的列表。

Table 50.30. pg_largeobject

列类型

描述

loid oid (引用 pg_largeobject_metadata.oid

包含此页的大对象的标识符

pageno int4

此页在它所属大对象中的页号(从0开始计)

data bytea

实际存储在大对象中的数据。它从不会超过LOBLKSIZE字节,也可能更少。


pg_largeobject的每一行保存一个大对象的一个页的数据,从对象内部的字节偏移量(pageno * LOBLKSIZE)开始。现在的实现允许稀疏存储:页面可能丢失,并且可能比LOBLKSIZE字节短(即便不是最后一页)。一个大对象中丢失的区域会被读出为0。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。