Пример: Определение владельцев домена с помощью SQL

Для определения владельцев всех доменов базы геоданных посредством запроса таблиц GDB_ItemTypes и GDB_Items (или GDB_Items_vw view в Oracle) можно использовать запросы SQL.

В следующих примерах показано, как извлекать значения из определенных документов XML с помощью выражения XPath для обнаружения владельцев всех доменов в определенной базе геоданных.

Перед выполнением запроса обязательно необходимо подключиться к правильной базе геоданных.

--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');

5/25/2014