全国高分辨率土地利用数据服务 土地利用数据服务 土地覆盖数据服务 坡度数据服务 土壤侵蚀数据服务 全国各省市DEM数据服务 耕地资源空间分布数据服务 草地资源空间分布数据服务 林地资源空间分布数据服务 水域资源空间分布数据服务 建设用地空间分布数据服务 地形、地貌、土壤数据服务 分坡度耕地数据服务 全国大宗农作物种植范围空间分布数据服务
多种卫星遥感数据反演植被覆盖度数据服务 地表反照率数据服务 比辐射率数据服务 地表温度数据服务 地表蒸腾与蒸散数据服务 归一化植被指数数据服务 叶面积指数数据服务 净初级生产力数据服务 净生态系统生产力数据服务 生态系统总初级生产力数据服务 生态系统类型分布数据服务 土壤类型质地养分数据服务 生态系统空间分布数据服务 增强型植被指数数据服务
多年平均气温空间分布数据服务 多年平均降水量空间分布数据服务 湿润指数数据服务 大于0℃积温空间分布数据服务 光合有效辐射分量数据服务 显热/潜热信息数据服务 波文比信息数据服务 地表净辐射通量数据服务 光合有效辐射数据服务 温度带分区数据服务 山区小气候因子精细数据服务
全国夜间灯光指数数据服务 全国GDP公里格网数据服务 全国建筑物总面积公里格网数据服务 全国人口密度数据服务 全国县级医院分布数据服务 人口调查空间分布数据服务 收入统计空间分布数据服务 矿山面积统计及分布数据服务 载畜量及空间分布数据服务 农作物种植面积统计数据服务 农田分类面积统计数据服务 农作物长势遥感监测数据服务 医疗资源统计数据服务 教育资源统计数据服务 行政辖区信息数据服务
Landsat 8 高分二号 高分一号 SPOT-6卫星影像 法国Pleiades高分卫星 资源三号卫星 风云3号 中巴资源卫星 NOAA/AVHRR MODIS Landsat TM 环境小卫星 Landsat MSS 天绘一号卫星影像
我们在使用AO的时候,可能都频繁接触过过滤器对象IQueryFilter,无论是空间过滤器还是普通过滤器,都有个属性WhereClause,而这里就是我们传递SQL语句的地方。
在笔者的书中,我讨论了查询数值和字符串的两种类型字段的方法,至少还有如下的问题:
1.这些SQL语句与普通的关系数据库的SQL语句有什么区别和联系?
2.如何查询时间?
3.可以使用诸如Order By一类的语法吗?
对于这些问题,我最近一直在看ArcSDE方面的资料,对于开发者而言,ArcSDE拥有三套开发集,即C API、JAVA API和AO的GeoDatabase部分,其中前两个是给非ESRI程序调用的,第三个是给ESRI程序使用的,显然,C API的效率应该是最高的。这点我曾经在一个SDE for CAD Client例子中看到过。
我们在逻辑上可以将一个要素类看作是一张表,当然,ArcSDE是使用一张或多张表来实现一个要素类的,这取决于DBMS的类型、几何字段类型和这个要素类是否将处于一个长事物过程中。ArcSDE不会改变一个已经存在的DBMS,它仅仅是一个中间件产品,它提供了工具和接口,扩展了标准的SQL函数。
当我们将一个空间字段添加到一个表的时候(这个表称为业务表,Business Table),ArcSDE的元数据表metatable会存储这个要素类表的元数据属性,如要素类名、空间范围、所有者、空间字段类型。这个metatable是ArcSDE安装的时候建立的。
ArcSDE存储几何数据采用了有序坐标与真实曲线结合的方式,如点是单个的XY坐标,而线则是由有序坐标和曲线Curve组成,这是因为直线当然可以由有序坐标集来构成,但万一线中出现完全部分,使用真实的曲线对象则更好一点。ArcSDE在考虑Annotation上是非常特殊的,它将Annotation当作是“一个要素的属性”,即ArcSDE还是存储的要素,但这个要素中有个特殊的BLOB字段,用于储存一个Text的对象,这个Text与一个坐标相关联。另外,ArcSDE的Annotation与AO Geodatabase的Annotation是有区别的(有什么区别,我还没注意到)。
不同的DBMS采用不同类型的字段来保存几何信息,如Oracle分别使用Long Raw或BLOB字段,如果装有Oracle的空间模块,则是SDO_Geometry字段,MS的SQL产品都是使用IMAGE类型字段来保存数据的。