大家对Oracle数据库的SQL操作应该不陌生吧,也就是出于所谓的效率而言,使用SQL语句对ArcGIS对象(要素类)进行直接的读操作或写操作,目前来说在电信行业运用较广泛,这方面的知识我就不再赘述。那么可能会有人问,那么在SQL Server数据库是否可以使用SQL语句直接操作ArcSDE的对象呢?以前不可以,但是现在可以了。
为什么说上面故意卖个关子呢,也就是需要强调一下系统需求的重要性。也就是说从SQL Server 2008版本后,才可以的。自从2008版本之后,MS提供了为空间数据专有的也就是MS自己的存储:Geometry和Geogrphy。
ArcSDE 地理数据库支持使用 Microsoft 的几何类型和地理类型存储矢量数据。SQL Server 2008 中提供这些类型,因此无需单独安装即可使用。这个与比较繁杂的Oracle的SQL操作引用St_shapelib.dll来说就显得非常方便了。
Microsoft 几何类型(Geometry)与现有 GIS 空间数据类型相似:使用任意平面(如已定义的投影)内的坐标。
Microsoft 地理类型(Geometry)用于旋转椭球体上的数据,该数据与纬度和经度坐标一同存储。
geometry 和 geography 数据类型支持十一种空间数据对象或实例类型。但是,这些实例类型中只有七种“可实例化”;可以在数据库中创建并使用这些实例(或可对其进行实例化)。这些实例的某些属性由其父级数据类型派生而来,使其在 GeometryCollection 中区分为 Points、 LineStrings、Polygons 或多个 geometry 或 geography 实例。
如图所示,geometry 和 geography 数据类型的七种可实例化类型为 Point、MultiPoint、LineString、MultiLineString、Polygon、MultiPolygon 和GeometryCollection。只要特定实例的格式正确,即使未显式定义该实例,geometry 和 geography 类型也可识别该实例。例如,如果您使用STPointFromText() 方法显式定义了一个 Point 实例,只要方法输入的格式正确,geometry 和 geography 便将该实例识别为 Point。如果您使用STGeomFromText() 方法定义了相同的实例,则 geometry 和 geography 数据类型都将该实例识别为 Point。
默认情况下,SQL Server 中的 ArcSDE 地理数据库使用 ArcSDE 压缩二进制类型,因此如果您要使用 Microsoft 几何或地理类型进行存储,必须
(1) 将 SDE_dbtune 表中 DEFAULTS 配置关键字下的 GEOMETRY_STORAGE 参数更改为 GEOMETRY 或 GEOGRAPHY
(2) 指定可在创建要素类时指定 GEOMETRY 或 GEOGRAPHY 的 GEOMETRY_STORAGE 参数的配置关键字。
如果多数用户在多数时候都使用几何或地理类型存储数据,则只应更改 DEFAULTS 关键字下的 GEOMETRY_STORAGE 参数。如果只有部分数据将以几何或地理类型进行存储,则应在创建要素类时指定一个单独的关键字。为您提供了两个关键字:GEOMETRY 和 GEOGRAPHY,也可以创建自己的自定义关键字。
用户在创建要素类或者导入要素类的过程中可以选择以上关键字,那么这些数据就已MS的几何或者地理类型进程存储了,那么用户也就可以使用SQL对数据进行操作了。
因为Geometry和Geogrphy基本类似,那么本文就已Geometry存储来演示一下怎么在ArcSDE的SQL Server使用SQL对空间数据进行操作
//如果是Geogrphy存储就替换一下即可 CREATE TABLE SpatialTable1 ( id int IDENTITY (1,1), GeomCol1 geometry, GeomCol2 AS GeomCol1.STAsText() ); GO
C:/Users/gis>sdelayer -o register -l SpatialTable1,GeomCol1 -e a -t GEOMETRY -u sde -p sde -i esri_sdesql ArcSDE 10.0 for SQL Server Build 775 Fri Sep 17 11:45:27 2010 Layer Administration Utility ----------------------------------------------------- Successfully Created Layer.
INSERT INTO SpatialTable1 (GeomCol1,objectid) VALUES (geometry::STGeomFromText('POLYGON ((0 0, 0 150, 150 150, 150 0, 0 0))', 0),1); GO INSERT INTO SpatialTable1 (GeomCol1,objectid) VALUES (geometry::STGeomFromText('POLYGON ((0 0, 0 75, 75 75, 75 0, 0 0))', 0),1); GO INSERT INTO SpatialTable1 (GeomCol1,objectid) VALUES (geometry::STGeomFromText('POLYGON ((100 100, 300 100, 300 300, 100 300, 100 100))', 0),3); GO
DECLARE @geom1 geometry; DECLARE @geom2 geometry; DECLARE @result geometry; SELECT @geom1 = GeomCol1 FROM SpatialTable1 WHERE objectid = 1; SELECT @geom2 = GeomCol1 FROM SpatialTable1 WHERE objectid = 3; SELECT @result = @geom1.STIntersection(@geom2); SELECT @result.STAsText();
微软为我们提供了丰富的空间关系操作符
Ø 确定两个实例是否包含相同的点集STEquals Ø 确定两个实例是否不相接STDisjoint Ø 确定两个实例是否相交STIntersects Ø 确定两个实例是否接触STTouches Ø 确定两个实例是否重叠STOverlaps Ø 确定两个实例是否交叉STCrosses Ø 确定某个实例是否在另一个实例内部STWithin Ø 确定某个实例是否包含另一个实例STContains Ø 确定某个实例是否与另一个实例重叠STOverlaps Ø 确定两个实例是否存在空间关系STRelate Ø 确定两个几何图形中的点之间的最短距离STDistance
大家可能都知道Oracle的一些关系操作符,有些走空间索引,有些不走空间索引,那么我们在使用这些关系操作符时一定要使用走空间索引的,那么对SQLServer来说也是一样的。
在特定条件下,空间索引支持以下面向集合的几何图形方法:STContains()、STDistance()、STEquals()、STIntersects()、STOverlaps()、STTouches() 和 STWithin()。若要使空间索引支持这些方法,必须在查询的 WHERE 或 JOIN ON 子句中使用这些方法,并且必须在采用如下常规形式的谓词中执行这些方法:
geometry1.method_name(geometry2) comparison_operatorvalid_number
若要返回非 NULL 结果,geometry1 和 geometry2 必须具有相同的空间引用标识符 (SRID)。否则,该方法将返回 NULL。
所有非空 geometry 实例都由“点”组成。这些点表示在其上绘制几何图形的面的 X 和 Y 坐标。geometry 提供许多用于查询实例的点的内置方法。
Ø 返回构成实例的点数。STNumPoints(geometry 数据类型) Ø 返回实例中的特定点STPointN Ø 返回位于实例上的某个任意点STPointOnSurface Ø 返回实例的起始点STStartPoint Ø 返回实例的终点STEndpoint Ø 返回点实例的 X 坐标STX(geometry 数据类型) Ø 返回点实例的 Y 坐标STY Ø 返回多边形实例的几何中心点STCentroid
非空 geometry 实例可以为零维、一维或二维。零维 geometries(例如 Point 和 MultiPoint)没有长度或面积。一维对象(例如 LineString 和 MultiLineString)具有长度。二维实例(例如 Polygon 和 MultiPolygon)具有面积和长度。空实例将报告为 -1 维,并且GeometryCollection 将根据其内容类型报告一个面积。
Ø 返回实例的维度STDimension Ø 返回实例的长度STLength Ø 返回实例的面积STArea
“闭合的”geometry 实例是指起始点和终点相同的图形。Polygon 实例是闭合的。Point 实例不是闭合的。
环是一个简单、闭合的 LineString 实例。
Ø 确定实例是否闭合STIsClosed Ø 确定实例是否为环STIsRing Ø 返回多边形实例的外环STExteriorRing Ø 返回多边形的内环数STNumInteriorRing Ø 返回多边形的指定内环STInteriorRingN
空间引用标识符 (SRID) 是指定 geometry 实例所在的坐标系的标识符。两个拥有不同 SRID 的实例是不可比的。
Ø 设置或返回实例的 SRIDSTSrid
此属性可以进行修改。
更多详见:http://msdn.microsoft.com/zh-cn/library/bb964708.aspx
两种空间数据类型的行为经常非常相似,但在数据存储方式和操作方式上存在某些重要的差别。
http://msdn.microsoft.com/zh-cn/library/bb964711.aspx
http://msdn.microsoft.com/zh-cn/library/bb895335.aspx
-------------------------------------------------------------------------------------------------------
版权所有,文章允许转载,但必须以链接方式注明源地址,否则追究法律责任!
QQ一群: 78773981
QQ二群: 225989940
Blog: http://blog.csdn.net/linghe301