在实际工作中,我们可能会遇到地理信息数据的存取。在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节“管理空间索引”。

相关文章:

  • 2021-07-25
  • 2021-10-07
  • 2021-04-05
  • 2021-10-03
  • 2021-07-27
  • 2021-08-14
  • 2022-01-12
  • 2021-08-02
猜你喜欢
  • 2021-12-03
  • 2021-06-22
  • 2021-05-16
  • 2021-10-18
  • 2021-10-16
  • 2021-06-22
  • 2021-06-12
相关资源
相似解决方案