前两天在实现一个SQL的时候,需要计算平面上2点间的距离,如果使用SQL函数实现,代码比较长,于是想到能否利用空间数据库的结构来实现这个功能。
测试环境为11.1.0.6,如果是9i,由于没有创建同义词,还需要在SDO对象的前面加上MDSYS前缀。
这里借用MDSYS的SDO_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/