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

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

 

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

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

 

1.启用DMGEO系统包

 

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

 

 

 

2.创建测试表

 

 

 

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

 

3.地理数据录入

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

 

 

4.地理信息查询


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

 

 

查询结果集如下

 

 

 

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

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

 

5.几何信息运算

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

得到的结果集如下:

 

 

 

 

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

 

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值