`
holoblog
  • 浏览: 1270289 次
博客专栏
E0fcf0b7-6756-3051-9a54-90b4324c9940
SQL Server 20...
浏览量:19615
文章分类
社区版块
存档分类
最新评论

SQL Servr 2008空间数据应用系列四:基础空间对象与函数应用

 
阅读更多

  友情提示,您阅读本篇博文的先决条件如下:

  1、本文示例基于Microsoft SQL Server 2008 R2调测。

  2、具备 Transact-SQL 编程经验和使用 SQL Server Management Studio 的经验。

  3、熟悉或了解Microsoft SQL Server 2008中的空间数据类型。

  4、具备相应(比如OGC)的GIS专业理论知识。

  5、其他相关知识。


  SQL Server 2008中支持的7种基础空间对象实例,分别为:点(Point)、点集合(MultiPoint )、线(LineString)、线集合(MultiLineString)、多边形(Polygon )、多边形集合(MultiPolygon)和空间集合(GeometryCollection)。本篇意在为大家介绍SQL Server 2008空间数据库系统组成部分中的基础空间对象以及系统内置的相关函数API,并就这些开发API进行介绍基于SQL Server 2008空间数据库系统的开发与应用。

  

一、点(Point)

  在 SQL Server 空间数据中,Point 是表示单个位置的零维对象,可能包含 Z(仰角)和 M(度量)值。可以通过下面SQL创建一个点的示例,默认该点的SRID(空间引用标识)为0。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->DECLARE@pgeometry;
SET@p=geometry::Parse('POINT(30.6666587469201 104.062021177233)');
select@p.STXASX;
select@p.STYASY;

  如下SQL命令这创建了包含 Z(仰角)和 M(度量)值的点(Point)实例,其中Z(仰角)和 M(度量)值可以显示的指定为“null”。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->DECLARE@ggeometry;
SET@g=geometry::Parse('POINT(30.6666587469201104.062021177233153.5)');
--SET@g=geometry::Parse('POINT(30.6666587469201104.062021177233nullnull)');
select@g.STXASX
select@g.STYASY
select@g.ZasZ
select@g.MasM

二、点集合(MultiPoint

  MultiPoint 是零个点或更多个点的集合。MultiPoint 实例的边界为空。其实需要使用函数STGeomFromText()来格式化被定义的数据按照OGC标准输出WKT格式的空间数据结果,也可使用函数STMPointFromText()代替STGeomFromText()的使用,通过如下SQL命令可定义一个点集合对象实例,并使用函数STGeometryN()输出空间数据结果:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->--创建点集合实例
DECLARE@cdgeometry;
SET@cd=geometry::STGeomFromText('MULTIPOINT((30.6666587469201104.062021177233),(29.5076372217973106.489384971208))',4326);
--SET@cd=geometry::STMPointFromText('MULTIPOINT((30.6666587469201104.062021177233),(29.5076372217973106.489384971208))',4326);
select@cd.STGeometryN(1).STAsText()as重庆;
select@cd.STGeometryN(2).STAsText()as成都;
---------------------------------------------------------------------------------------
执行输出结果:

重庆
---------------------------------------------------------------------------------------
POINT (30.6666587469201 104.062021177233)

成都
---------------------------------------------------------------------------------------

POINT (29.5076372217973 106.489384971208)

三、线(LineString)

  LineString 是一个一维对象,表示一系列点和连接这些点的线段。一个 LineString 实例必须由至少两个非重复点组成,也可以为空。线条描述了空间上的两个或多个点之间的距离,必须有两个端点,分别为:起止点(StartPoint)和终止点(EndPoint)。如下SQL命令实现了定义重庆到成都两点之间的线条:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->DECLARE@cdlinegeometry;
SET@cdline=geometry::STGeomFromText('LINESTRING(30.6666104.06202,29.50763106.48938)',4326);
select@cdline.STAsText()as重庆_成都
-------------------------------------------------------------------------------------------
重庆_成都
-------------------------------------------------------------------------------------------
LINESTRING(30.6666104.06202,29.50763106.48938)

  在SQL Server 2008的空间结果中所呈现的效果如下图所示:

        

  注:线条有多种外观呈现方式,有非闭合线条、闭合线条以及图形复杂的线条等多种情况出现。如上(右)图示。

四、线集合(MultiLineString)

  MultiLineString 是零个或更多 geometry 或 geography LineString 实例的集合。为使 MultiLineString 实例有效,该实例必须满足以下条件:

  1、构成 MultiLineString 实例的所有实例必须都是有效的 LineString 实例。

  2、在构成 MultiLineString 实例的 LineString 实例中,不能有两个实例在某一段间隔上重叠。LineString 实例只能与自身相交或接触,或者在有限数目的点上与其他 LineString 实例相交或接触。

  通过如下SQL代码片段演示MultiLineString的具体使用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->DECLARE@mlgeometry;
--SET@ml=geometry::Parse('MULTILINESTRING((30.6666104.06202,29.50763106.48938),(30.6666104.06202,33.78142105.97914))');
SET@ml=geometry::STGeomFromText('MULTILINESTRING((30.6666104.06202,29.50763106.48938),(30.6666104.06202,33.78142105.97914))',4326);
--SET@ml.STSrid=4326;
select@ml;
select@ml.STIsValid(); --验证ml对象是否为正确的空间对象

        

五、多边形(Polygon

  Polygon 是存储为一系列点的二维表面,这些点定义一个外部边界环和零个或多个内部环。可以从至少具有三个不同点的环中构建一个 Polygon 实例。以下SQL命令演示了如何创建多边形以及求多边形的面积函数的应用。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->--创建多边形
DECLARE@pggeometry;
SET@pg=geometry::STPolyFromText('POLYGON((00,03,33,30,00),(11,12,21,11))',10);
select@pg;
select@pg.STArea();--求得多边形的面积

六、多边形集合(MultiPolygon

  多边形集合(MultiPolygon )实例是零个或更多个 Polygon 实例的集合。下面的SQL命令演示了定义一个多边形集合对象并返回第一个对象的WKT。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->--创建多边形集合,并返回第一个多边形的WKT
DECLARE@mpggeometry;
SET@mpg=geometry::Parse('MULTIPOLYGON(((11,12,21,11)),((99,910,109,99)))');
SELECT@mpg.STGeometryN(1).STAsText();
---------------------------------------------------------------------------------------------
执行输出结果:
POLYGON((
11,12,21,11))

七、空间对象集合(GeometryCollection )

  GeometryCollection 是零个或更多个 geometry 或 geography 实例的集合。GeometryCollection 可以为空。以下SQL演示了定义一个带有一个点(Point)实例和一个多边形(Polygon)实例的空间对象集合对象。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->--空间集合
DECLARE@ggcgeometry;
SET@ggc=geometry::STGeomCollFromText('GEOMETRYCOLLECTION(POINT(331),POLYGON((002,1103,104,002)))',1);
select@ggc;
select@ggc.STAsText();--输出WKT文本(不带Z,M值)
select@ggc.ToString();--输出对象原字符串(带Z,M值)
--
-------------------------------------------------------------------------------------------
执行输出结果:
---------------------------------------------------------------------------------------------
0x010000000105050000000000000000000840000000000000084000000000000000000000000000000000000000000000F03F0000000000002440000000000000F03F000000000000000000000000000000000000000000000000000000000000F03F0000000000000040000000000000084000000000000010400000000000
--
-------------------------------------------------------------------------------------------
GEOMETRYCOLLECTION(POINT(33),POLYGON((00,110,10,00)))
--
-------------------------------------------------------------------------------------------
GEOMETRYCOLLECTION(POINT(331),POLYGON((002,1103,104,002)))

八、SQL Server 2008函数应用

  SQL Server 2008中针对地理空间数据、对象、实例提供了非常丰富的内置函数,使用这些函数可以快速的完成一系列的空间数据分析。关于这些函数的具体使用这里就不逐一介绍,本文中也相应的使用了几个常用的OGC静态几何图形方法,以后的博文使用中会根据使用情况再做介绍,详细请大家查阅MSDN,本文末也提供了相关参考资料的链接。下面代码演示了测距重庆到成都两点之间坐标的距离(单位:米)。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->DECLARE@chongqinggeography=geography::Point(30.6666587469201,104.062021177233,4326)
DECLARE@chengdugeography=geography::Point(29.5076372217973,106.489384971208,4326)
SELECT@chongqing.STDistance(@chengdu)
-----------------------------------------------------------------------------------------
执行结果为:266943.740244237

九、相关资料

  [1]、空间数据库(百度百科):http://baike.baidu.com/view/1194566.htm

  [2]、使用空间数据实现位置智能:http://tech.ddvip.com/2008-04/120816526343873.html

  [3]、基础空间对象(MSDN):http://msdn.microsoft.com/de-de/library/bb964711.aspx

  [4]、几何实例上的OGC方法:http://msdn.microsoft.com/zh-cn/visualc/bb933960.aspx

  [5]、几何图形实例上的扩展方法:http://msdn.microsoft.com/zh-cn/library/bb933880.aspx

  [6]、OGC 静态几何图形方法:http://msdn.microsoft.com/zh-cn/library/bb933894.aspx

  [7]、扩展静态几何图形方法:http://msdn.microsoft.com/zh-cn/library/bb933805.aspx

分享到:
评论

相关推荐

    数据库应用教程(Visual Basic+SQL Server).rar

    数据库应用教程,特别是结合Visual Basic和SQL Server的实践,是IT领域中一项基础且重要的学习内容。这个压缩包文件提供了一套完整的教学资源,旨在帮助学习者掌握如何使用这两种技术来构建、管理和交互数据。 首先...

    SQLServr关键字.doc

    - **作用**:与 `SELECT` 语句一起使用的一个操作符,用于查找指定范围内的所有值。 - **示例**:`SELECT * FROM Orders WHERE OrderDate BETWEEN '2023-01-01' AND '2023-03-31';` 13. **BREAK** - **作用**:...

    SQL server 2005.rar

    3. 数据查询:深入理解JOIN操作、子查询、聚合函数和窗口函数的应用。 4. 存储过程和触发器:学习如何编写和调用存储过程,以及使用触发器实现数据的自动操作。 5. 数据备份与恢复:了解如何制定备份策略,执行完整...

    SQL大全.rar

    《SQL大全》是一本深入探讨SQL(Structured Query Language)的教程,主要针对数据库管理与数据操作。SQL是用于管理和处理关系数据库的标准编程语言,广泛应用于数据查询、更新、增删等操作,也是数据分析和开发人员...

    sql面试例子.rar

    中级题目可能涉及到查询语句(SELECT),如选择特定列、使用WHERE子句过滤数据、使用GROUP BY进行数据分组和聚合函数(COUNT、SUM、AVG、MIN、MAX)的运用。JOIN操作也是重点,包括内连接(INNER JOIN)、左连接...

    深度对比Oracle与SQL Server

    Oracle通过init.ora或spfile设置参数,SQL Server使用注册表或配置文件(如sqlservr.exe.config)进行配置。 10. **更改系统元数据和参数配置**: Oracle通过ALTER SYSTEM命令修改参数,DDL语句修改元数据;SQL ...

    Microsoft SQL Server 2005 Express Edition SP3

    与 Microsoft Visual Studio 2005 集成之后,SQL Server Express 可以轻松的开发功能强大且安全的数据驱动应用程序,并允许快速部署这些应用程序。SQL Server Express 可以根据协议重新进行发布,并可作为客户端...

    数据库补丁.rar

    补丁可能涉及到SQL语句、存储过程、触发器、函数,或者是数据库管理系统的内核部分。 从压缩包文件的名称来看,我们可以推测这可能是某个数据库竞赛或者项目中的资料,如"08国赛本"可能指的是2008年的全国数据库...

    mssql_server_tiny:稍微解放的Microsoft SQL Server Docker映像

    mssql_server_tiny 什么 略微修改的Microsoft SQL Server docker映像修改为允许在物理内存少于2 ... 当sqlservr调用“ sysinfo”系统调用(以查看主机具有多少物理内存)时,我们改为使用重新定义的sysinfo函数对sqlse

    navicat12数据库连接

    10. **对象设计器**:提供了完善的数据库对象设计器,如表设计器、视图设计器和函数/存储过程编辑器,用户可以方便地创建和修改数据库对象。 11. **实时监控**:通过实时监控功能,用户可以查看数据库服务器的性能...

    CentOS安装SQL Server vNext CTP1教程

    - SQL Server的`ROUND`函数及其与`CAST`和`CONVERT`的使用 - SQL Server日期函数的`CAST`和`CONVERT`在业务中的应用 - SQL Server 2012中转换函数的比较:`Cast`、`Convert`和`Parse` - 解决SQL Server的各种错误和...

    Delphi 常见问题整理

    启动 SQL Server 服务可以通过命令行工具 `sqlservr.exe` 来实现。在 Windows 命令提示符中输入以下命令: ```shell net start MSSQLSERVER ``` #### 八、Application.MessageBox 的使用 `Application.MessageBox`...

    MSSQL木马修复,中木马后的处理方法

    在IT安全领域,数据库系统受到木马病毒的攻击是一个严重的问题,尤其是对于使用Microsoft SQL Server (MSSQL)的企业和组织。一旦MSSQL服务器被植入木马,它可能导致数据泄露、系统瘫痪甚至整个网络环境的安全风险。...

Global site tag (gtag.js) - Google Analytics