ArcGIS10已经推出快一年的时间了,在去年的用户大会上关于Geodatabase10的新特性上描述我们的相关Schema也发生了本质的变化,从原来的30多张表,变成现在的6张,那么最本质的变化就是相关的对象使用XML进行存储,这对我们开发者来说是一个好消息,因为我们可以通过XML结构来得知每一个对象是怎么定义的,而且我们也可以使用SQL来读取XML的值而不用使用ArcObject来读取。
关于Geodatabase10新特性可以参考:http://wenku.baidu.com/view/94721478168884868762d668.html
那么今天就给大家介绍一下怎么使用C#来访问这些值,其实抛开ArcGIS的知识,一个纯IT的开发人员只要了解XML的都会很容易的来获得这些信息。
首先看一下一个要素类为DLTB的XML格式
我们可以看到,这个XML定义了要素类的名称、字段(字段的相关属性)、投影信息、范围等信息
------------------------Oracle----------------------------------------------------------------
在Oracle数据库中的存储并不是直接存储在Defination里面
而且需要使用sde.sdexmltotext操作符来转换一下
参考示例代码
----------------------------------------------SQL Server----------------------------------
在SQL Server中,完全使用SQL语句直接对XML进行获得值,而不需要引用C#的类库
----------------------------------------------Oracle----------------------------------
SELECT
EXTRACTVALUE(XMLType(Definition), '/DEWorkspace/MajorVersion') AS "Major version",
EXTRACTVALUE(XMLType(Definition), '/DEWorkspace/MinorVersion') AS "Minor version",
EXTRACTVALUE(XMLType(Definition), '/DEWorkspace/BugfixVersion') AS "Bug fix version"
FROM
sde.gdb_items_vw items INNER JOIN
(SELECT UUID
FROM sde.gdb_itemtypes
WHERE Name = 'Workspace') itemtypes
ON items.Type = itemtypes.UUID;
---------------------------------------File Geodatabase---------------------------------
如果用户使用FGDB,那么可以使用FileGDB API来获得相关的信息