C#开发读取Geodatabase10的XML值

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里面

image

而且需要使用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来获得相关的信息

 

 

 

 

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值