示例:使用 SQL 查找属性域所有者
可使用 SQL 查询表 GDB_ItemTypes 和 GDB_Items(或 Oracle 中的 GDB_Items_vw 视图),从而在地理数据库中查找所有属性域的所有者。
以下示例介绍如何使用 XPath 表达式从特定 XML 文档中提取值,以在特定地理数据库中查找所有属性域的所有者。
请确保在执行此查询之前已连接到正确的数据库。
--SQL Server SELECT items.Name AS "Domain Name", items.Definition.value('(/*/Owner)[1]','nvarchar(max)') AS "Owner" FROM dbo.GDB_ITEMS AS items INNER JOIN dbo.GDB_ITEMTYPES AS itemtypes ON items.Type = itemtypes.UUID WHERE itemtypes.Name IN ('Coded Value Domain', 'Range Domain')
--PostgreSQL SELECT items.name AS "Domain Name", (xpath('//Owner/text()', definition))[1]::text as "Owner" FROM sde.gdb_items AS items INNER JOIN sde.gdb_itemtypes AS itemtypes ON items.type = itemtypes.uuid WHERE itemtypes.name IN ('Coded Value Domain', 'Range Domain');
--Oracle SELECT items.name AS domain_name, EXTRACTVALUE(xmltype(items.definition), '*/Owner') Owner, itemtypes.Name AS domain_type FROM sde.gdb_items_vw items INNER JOIN sde.gdb_itemtypes itemtypes ON items.Type = itemtypes.UUID WHERE itemtypes.Name IN ('Coded Value Domain', 'Range Domain');
7/10/2012