ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 利用空间数据库求两点距离

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

原创 Linux操作系统 作者:yangtingkun 时间:2009-02-14 23:06:32 0 删除 编辑

前两天在实现一个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/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
暂无介绍

注册时间:2007-12-29

  • 博文量
    1955
  • 访问量
    10442151