上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

在实际工作中,我们可能会遇到地理信息数据的存取。在DM7中,我们提供了DMGEO这个系统包来调用空间数据类型以及使用相关函数。下面,我就用一个模拟案例来跟大家演示。

 

演示环境:DM Database Server x64V7.1.6.46-Build(2018.02.08-89107)ENT

实验背景:现有一模拟城市地图如下,我们应该如何在数据库中存取相关数据呢?

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

1.启用DMGEO系统包

 

要调用空间数据相关函数,我们必须要先创建DMGEO系统包,相关代码如下

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

 

 

2.创建测试表

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

 

 

这里采用的数据类型ST_POLYGON,是DMGEO中的面类。补充一点,达梦的空间数据类型是以类的方式进行体现的。

 

3.地理数据录入

这里,我们采用ST_POLYFORMATEXT函数来构造面类

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

 

4.地理信息查询


首先,我们可以利用ST_WITHIN函数查出全城所有的地理信息

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

 

查询结果集如下

 

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

假如我们只想查出阴影部分中所有公园的信息,那么代码如下

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

要注意的是,如果想利用ST_WITHIN函数来计算包含关系,这种包含关系是涵盖边界的。

 

5.几何信息运算

假设我们想知道甲公园和乙公园之间的距离,我们可以利用函数ST_DISTANCE来求两个几何体之间的最小距离。相关代码如下:

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

得到的结果集如下:

 

 

上海腾科教育达梦数据库培训干货分享空间数据类型在DM7中的使用

 

 

从图中利用勾股定理可以得知,甲公园和乙公园的最小距离√5,与函数得出的结果相同。

 

在实际工作,我们为了优化空间数据的查询,可以在相关的列上建立空间索引,这里因为篇幅原因就不详细介绍了。如果大家对这方面的内容感兴趣,可以参考DM7安装目录中DOC目录下的《DM系统包使用手册》第二章“DMGEO包”和《DM7 SQL使用手册》3.10节“管理空间索引”。