定义
GlobalID_Name 将表作为输入参数,返回表中全局 ID 字段的名称。
添加全局 ID 字段的目的是使表能够参与地理数据库复制或离线地图使用。GlobalID_Name 函数不返回 GUID 字段的名称。
如果使用 ArcObjects 以编程方式创建全局 ID 字段并且不确定所创建字段的名称,可使用 GlobalID_Name。如果使用 ArcGIS for Desktop、添加全局 ID 地理处理工具或 Python 脚本已将全局 ID 字段添加到表中,则字段名称始终为 globalid;因此,不必使用 GlobalID_Name 查找字段名称。
如果表中不包含全局 ID 字段,则会返回一个空字符串。如果表未注册到地理数据库或者表不存在,则会返回一条指明表未注册到地理数据库的消息或者返回一个空字符串。
语法
<geodatabase administrator schema>.globalid_name (<table owner>, <table name>)
在大多数地理数据库中,地理数据库管理员方案是 sde。但是,在 SQL Server dbo 方案地理数据库中,则为 dbo;而在 Oracle 用户方案地理数据库中,则为用户方案的名称。
返回类型
字符串
示例
下面是在支持的各种数据库类型中使用 GlobalID_Name 函数的示例。
第一个示例查询由 insp3 拥有的 signs 表中全局 ID 字段的名称。
第二个示例查询由 planner 拥有的 addresses 表中全局 ID 字段的名称。该表不包含全局 ID 列。
第三个示例查询由 insp3 拥有的 partners 表中全局 ID 字段的名称。partners 表未注册到地理数据库。
DB2
VALUES sde.globalid_name('INSP3', 'SIGNS')
SIGNID
VALUES sde.globalid_name('PLANNER', 'ADDRESSES')
VALUES sde.globalid_name('INSP3', 'PARTNERS')
Oracle
SELECT sde.gdb_util.globalid_name('INSP3', 'SIGNS')
FROM DUAL;
SDE.GDB_UTIL.GLOBALID_NAME('INSP3', 'SIGNS')
--------------------------------------------------
SIGNID
SELECT sde.gdb_util.globalid_name('PLANNER', 'ADDRESSES')
FROM DUAL;
SDE.GDB_UTIL.GLOBALID_NAME('PLANNER', 'ADDRESSES')
--------------------------------------------------
SELECT sde.gdb_util.globalid_name('INSP3', 'PARTNERS')
FROM DUAL;
SDE.GDB_UTIL.GLOBALID_NAME('INSP3', 'PARTNERS')
--------------------------------------------------
ORA-20220: Class INSP3.PARTNERS not registered to the Geodatabase.
PostgreSQL
SELECT sde.globalid_name('insp3', 'signs');
signid
SELECT sde.globalid_name('planner', 'addresses');
SELECT sde.globalid_name('insp3', 'partners');
NOT REGISTERED
SQL Server
SELECT sde.globalid_name('insp3', 'signs');
SignID
SELECT sde.globalid_name('planner', 'addresses');
SELECT sde.globalid_name('insp3', 'partners');
NOT REGISTERED