在 PostgreSQL 中存储的地理数据中的 XML 列

XML 是一种用于在文档内部定义数据元素的开放标准。要将 XML 数据存储在 PostgreSQL 数据库中,可以使用 ArcSDE XML 列或本地 PostgreSQL XML 列。

您可以将用户定义的 XML 文档存储为任一类型的 XML 格式。参数 XML_COLUMN_STORAGE sde_dbtune 控制所采用的 XML 的类型。默认情况下,此参数设置为本地 PostgreSQL XML 数据类型。

ArcGIS for Desktop 中的 XML 列

地理数据库不完全支持 XML 列。因此,请注意以下事项:

PostgreSQL DBMS 中包含 XML 文档的列

有以下两种不同类型的 XML 列可供使用:ArcSDE XML 或 PostgreSQL 的本地 XML 类型。使用 sde_dbtune 表中的参数 XML_STORAGE,可以控制在数据集(创建于地理数据库中)中使用哪种 XML 类型。

如果使用本地 PostgreSQL XML 类型,则没有额外的地理数据库系统表对其进行跟踪,而是由 PostgreSQL 的系统表对其进行跟踪。

对于 ArcSDE XML,有三个地理数据库系统表可用于管理 XML 列:sde_xml_columns sde_xml_index_tagssde_xml_indexes。这三个表由 ArcSDE 管理员用户所有。ArcSDE 还会为每个 XML 列额外创建两个表,分别用于存储 XML 文档和为其建立索引:sde_xml_doc<column_id> 和 sde_xml_idx_<column_id> 表。如果某用户是含有 XML 文档的业务表的所有者,则该用户也是这两个表的所有者。

ArcGIS 将创建以下表,用于存储 XML 文档以及为其建立索引。

警告警告:

请勿使用 SQL 更改以下任何表。

sde_xml_columns

每当在业务表中添加一个列来存储 XML 文档,就会在 XML 列的表中添加一行。该表在每个 ArcSDE 地理数据库中都会出现一次。

字段名

字段类型

描述

是否允许为空

column_id

整型

XML 列的标识符和表的主键

在创建 XML 列时由 ArcSDE 分配此值。

NOT NULL

registration_id

整型

包含 XML 列的业务表的标识符以及系统表 table_registry 的外键

NOT NULL

column_name

varchar(32)

业务表中 XML 列的名称

NOT NULL

index_id

整型

与 XML 列(如果存在)相关联的 XPath 索引的标识符以及 sde_xml_indexes 表的外键

minimum_id

整型

在业务表的 XML 列中使用的初始编号值,用于标识各 XML 文档

config_keyword

varchar(32)

DBTUNE 配置关键字,它的参数可确定如何在数据库中定义 XML 文档、XML XPath 索引表以及针对这些表所创建的文本索引。

xflags

整型

指示 XML 文档表中的原始文档是以压缩形式存储还是以解压缩形式存储的值

默认情况下,文档以压缩形式存储,这是因为压缩后的文档可以提高性能。

NOT NULL

sde_xml_indexes

该表在每个 ArcSDE 数据库中都会出现一次。它为具有 XPath 索引的每个列都提供了一行空间。

字段名

字段类型

描述

是否允许为空

index_id

整型

XPath 索引的标识符以及表的主键

NOT NULL

index_name

varchar(32)

XPath 索引的名称

NOT NULL

owner

varchar(32)

拥有 XML 列的数据库用户

NOT NULL

index_type

整型

指示 XPath 索引类型的值

值为 2 表示索引类型 SE_XML_INDEX_DEFINITION,值为 1 表示索引类型 SE_XML_INDEX_TEMPLATE。

NOT NULL

描述

varchar(64)

用于标识 XPath 索引的文本

如果使用索引定义文件创建索引,则可以在文件顶部指定索引描述。

sde_xml_index_tags

包含 XML 文档的 XML 列可以使用 XPath 索引(是否使用取决于具体需要),这使您可以对每个文档中的特定 XML 元素或属性的内容进行搜索。有关每个 XPath 索引中包含或排除哪些元素和属性都在此表中进行定义。

该表在每个 ArcSDE 数据库中都会出现一次。它为与列的 XPath 索引相关联的每个 XPath 都提供一行空间。

字段名

字段类型

描述

是否允许为空

index_id

整型

与 XML 列(如果存在)相关联的 XPath 索引的标识符以及 sde_xml_indexes 表的外键

NOT NULL

tag_id

整型

XPath 或标记的标识符

NOT NULL

tag_name

varchar(1024)

对 XML 文档中可能出现的 XML 元素或属性进行标识的绝对 XPath

例如,/metadata/mdDateSt 用于标识 XML 元素,/metadata/dataIdInfo/tpCat/TopicCatCd/@value 用于标识 XML 属性。这些 XPath 不得使用星号 (*) 来指代一组 XML 元素或属性,每个元素或属性都按照此表中指定的 XPath 进行精确匹配。在有效的 XML 文档中,不能将元素命名为 *。

NOT NULL

data_type

整型

指示 XML 元素或属性的索引形式是数字、变长字符还是文本的值;值为 1 表示标记内容的索引形式是文本,值为 2 表示标记内容的索引形式是数字,值为 3 表示标记内容的索引形式是变长字符。

NOT NULL

tag_alias

整型

可以用来标识 XPath 的数字

例如,Z39.50 通信协议使用数字代码指示可搜索的内容。

描述

varchar(64)

对 XML 元素或属性中应包含的内容进行标识的文本

is_excluded

整型

指示 XPath 索引中是包含还是排除 XML 元素的值;0 = 包含 XPath;1 = 排除 XPath。

NOT NULL

sde_xml_doc<column_id>

sde_xml_doc<column_id> 表用于存储 XML 文档并对文档内容的全文索引进行维护。ArcSDE 数据库中针对每个包含 XML 文档的列都有一个这样的表。表名称中的数字是列的标识符。该表为存储在列中的每个 XML 文档都提供了一行空间。

字段名

字段类型

描述

是否允许为空

sde_xml_id

整型

存储在 XML 列中的 XML 文档的标识符以及表的主键

NOT NULL

doc_property

整型

指示在向 XPath 索引添加 XML 文档内容时是否发现任何冲突的值;1 = 发现一处冲突;例如,某个元素的索引形式本应是数字,而文档却在该元素中包含一个字符串。

xml_doc

bytea

XML 文档

NOT NULL

xml_doc_val

bytea

删除了所有 XML 标记和其他置标的整个 XML 文档的内容

默认情况下,系统为该列建立文本索引;此索引用于响应全文查询。

sde_xml_idx<column_id>

sde_xml_idx<column_id> 表是针对具有 XPath 文本索引的列而创建的。此表用于存储已建立索引的每个 XPath 的文本或数字内容。

表名称中的 ID 号是包含 XML 文档的列的内部注册号。

字段名

字段类型

描述

是否允许为空

xml_key_column

整型

索引值的标识符以及表的主键

NOT NULL

sde_xml_id

整型

包含索引值的 XML 文档的标识符

NOT NULL

tag_id

整型

与 XML 列的 XPath 索引相关联的标记的标识符,用于标识该值在文档中的存储位置

NOT NULL

double_tag

双精度型

在 XPath 索引定义中将标记定义为双精度型时的索引值

string_tag

varchar(256)

在 XPath 索引定义中将标记定义为变长字符时的索引值

text_tag

文本

在 XPath 索引定义中将标记定义为 STRING 时的索引值

下图展现了具有包含 XML 文档的列的表以及用于追踪该列的系统表。虚线表示表之间的隐含关系;实线表示表之间明确定义的关系。

PostgreSQL 中的站点业务表以及追踪 XML 列的关联系统表

XML 工作空间文档中包含 XML 文档的列

您不能将具有包含 XML 文档的列的表导出到 XML 工作空间文档中。可以将其导出到 XML 记录集文档中。

相关主题

9/15/2013