zoukankan      html  css  js  c++  java
  • ArcSDE中直接取得图层几何类型

            要取得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的值,然后将其转化为对应的要素类型。转换关系请参照下面的代码:

    public enum GeoType{Point,Line,Polygon,Anno,Raster,AttrTable,Unknown};

    public static GeoType GetGeoType(object GeometryType,object FeatureType)
            
    {
                
    if (GeometryType == DBNull.Value)
                    
    return GeoType.AttrTable;
                
    else if(GeometryType.ToString() == "2")
                
    {
                    
    return GeoType.Point;
                }

                
    else if (GeometryType.ToString() == "3")
                
    {
                    
    return GeoType.Line;
                }

                
    else if(GeometryType.ToString() == "4")
                
    {
                    
    if (FeatureType.ToString() == "1")
                        
    return GeoType.Polygon;
                    
    else if (FeatureType.ToString() == "11")
                        
    return GeoType.Anno;
                    
    else if (FeatureType.ToString() == "14")    
                        
    return GeoType.Raster;
                    
    else
                        
    return GeoType.Unknown;
                }

                
    else
                
    {
                    
    return GeoType.Unknown;
                }
        
            }


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

  • 相关阅读:
    【重大更新】Qlik Sense September 2018重磅发布(附下载)
    sharepoint多个NLB的web前段如何进行文件同步?
    通过组策略实现Firefox自动以当前域账号登录MOSS站点---(原创)
    EWS API 2.0读取日历信息-读取内容注意事项
    Dotfuscator混淆加密
    如何:在 SharePoint 中创建外部列表
    java学习笔记—HTTP协议(10)
    java学习笔记—Tomcat(9)
    java学习笔记DOM4J解析(7)
    php中mvc框架总结1(7)
  • 原文地址:https://www.cnblogs.com/watsonyin/p/387377.html
Copyright © 2011-2022 走看看