要取得SDE图层要素类型,一个方法就是打开该图层,然后通过取得DataSetType属性和FeatureType属性来判断,但这样做效率比较低。能不能通过SDE的系统表来获得呢,答案是可以的。
        要有到两张系统表:GDB_OBJECTCLASSES和GDB_FEATURECLASSES。
        其中GDB_OBJECTCLASSES表中相关字段有:ID、Name,GDB_FEATURECLASSES表的相关字段是:ObjectClassID、FeatureType、GeometryType,两个表的关联关系是:GDB_OBJECTCLASSES.ID=GDB_FEATURECLASSES.ObjectClassID。通过这两个表的关联,就可以取得指定图层要素类型了。
        我们可以先通过SQL语句根据图层名称来获取GDB_FEATURECLASSES表中字段FeatureType、GeometryType的值,然后将其转化为对应的要素类型。转换关系请参照下面的代码:

        }


       通过这种方式,速度很快,而且可以一次读出所有图层的图层基本信息和要素类型,速度极快。如果这些信息要经常使用的话,可以保存到一个哈希表中,这样只用连接一次数据库就OK了。
       

 

相关文章:

  • 2022-12-23
  • 2021-08-11
  • 2021-09-01
  • 2021-06-26
  • 2021-09-01
  • 2022-01-05
  • 2021-06-09
  • 2022-12-23
猜你喜欢
  • 2022-01-22
  • 2021-09-29
  • 2021-09-06
  • 2022-02-11
  • 2021-05-22
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案