利用空间数据库求两点距离

前两天在实现一个SQL的时候,需要计算平面上2点间的距离,如果使用SQL函数实现,代码比较长,于是想到能否利用空间数据库的结构来实现这个功能。

 

 

测试环境为11.1.0.6,如果是9i,由于没有创建同义词,还需要在SDO对象的前面加上MDSYS前缀。

这里借用MDSYSSDO_GEOMETRY对象,下面是一个简单的例子,计算(0 0)到(3 4)两点间的距离:

SQL> SELECT
  2   SDO_GEOM.SDO_DISTANCE(
  3    SDO_GEOMETRY(2001, NULL, SDO_POINT_TYPE(0, 0, NULL), NULL, NULL),
  4    SDO_GEOMETRY(2001, NULL, SDO_POINT_TYPE(3, 4, NULL), NULL, NULL),
  5    0.0001) DISTANCE
  6  FROM DUAL;

  DISTANCE
----------
         5

简单看一下SDO_GEOMETRY的结构:

SQL> DESC SDO_GEOMETRY
 
名称                                               是否为空? 类型
 -------------------------------------------------- -------- --------------------
 SDO_GTYPE                                                   NUMBER
 SDO_SRID                                                    NUMBER
 SDO_POINT                                                   MDSYS.SDO_POINT_TYPE
 SDO_ELEM_INFO                                               MDSYS.SDO_ELEM_INFO_ARRAY
 SDO_ORDINATES                                               MDSYS.SDO_ORDINATE_ARRAY

METHOD
------
 MEMBER FUNCTION GET_GTYPE RETURNS NUMBER

METHOD
------
 MEMBER FUNCTION GET_DIMS RETURNS NUMBER

METHOD
------
 MEMBER FUNCTION GET_LRS_DIM RETURNS NUMBER

METHOD
------
 MEMBER FUNCTION GET_WKB RETURNS BLOB

METHOD
------
 MEMBER FUNCTION GET_WKT RETURNS CLOB

METHOD
------
 MEMBER FUNCTION ST_COORDDIM RETURNS NUMBER

METHOD
------
 MEMBER FUNCTION ST_ISVALID RETURNS NUMBER

METHOD
------
 FINAL CONSTRUCTOR FUNCTION SDO_GEOMETRY RETURNS SELF AS RESULT
参数名称                       类型                    输入/输出默认值?
------------------------------ ----------------------- ------ --------
 WKT                            CLOB                    IN
 SRID                           NUMBER                  IN     DEFAULT

METHOD
------
 FINAL CONSTRUCTOR FUNCTION SDO_GEOMETRY RETURNS SELF AS RESULT
参数名称                       类型                    输入/输出默认值?
------------------------------ ----------------------- ------ --------
 WKT                            VARCHAR2                IN
 SRID                           NUMBER                  IN     DEFAULT

METHOD
------
 FINAL CONSTRUCTOR FUNCTION SDO_GEOMETRY RETURNS SELF AS RESULT
参数名称                       类型                    输入/输出默认值?
------------------------------ ----------------------- ------ --------
 WKB                            BLOB                    IN
 SRID                           NUMBER                  IN     DEFAULT

其中参数SDO_GTYPE的值2001表示是一个二维的点,这个类型的具体函数描述可以参考空间数据库的官方文档。

而随后的SDO_POINT构造了一个点的位置,然后通过SDO_GEOM.SDO_DISTANCE 函数来计算两个点的距离。

可能二维点的计算,这种方法和SQL直接计算没有太大的差别,而对于三维点而言,这种方式就显得简单得多了:

SQL> SELECT
  2   SDO_GEOM.SDO_DISTANCE(
  3    SDO_GEOMETRY(3001, NULL, SDO_POINT_TYPE(0, 0, 0), NULL, NULL),
  4    SDO_GEOMETRY(3001, NULL, SDO_POINT_TYPE(3, 4, 12), NULL, NULL),
  5    0.0001) DISTANCE
  6  FROM DUAL;

  DISTANCE
----------
        13

另外对于二维点,10g以上版本可以利用更简单的方法来构造:

SQL> SELECT
  2   SDO_GEOM.SDO_DISTANCE(
  3    SDO_GEOMETRY('POINT(0 0)'),
  4    SDO_GEOMETRY('POINT(3 4)'),
  5    0.0001) DISTANCE
  6  FROM DUAL;

  DISTANCE
----------
         5

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/4227/viewspace-551933/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/4227/viewspace-551933/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值