如何使用 Oracle 的 sdo_distance

Posted

技术标签:

【中文标题】如何使用 Oracle 的 sdo_distance【英文标题】:How to use Oracle's sdo_distance 【发布时间】:2013-02-05 23:58:28 【问题描述】:

我正在尝试计算 Oracle DB 中两点之间的距离,

Point A is 40.716715, -74.033907
Point B is 40.716300, -74.033900

使用这条sql语句:

SELECT   sdo_geom.sdo_distance( sdo_geom.sdo_geometry(2001 ,8307 ,sdo_geom.sdo_point_type(40.716715, -74.033907 , NULL) ,NULL ,NULL)
                           ,sdo_geom.sdo_geometry(2001 ,8307 ,sdo_point_type(40.716300,-74.033901, NULL) ,NULL ,NULL) ,0.0001 ,'unit=M') distance_in_m
                           from DUAL;

结果是12.7646185977151

在使用 Apple 的 CoreLocation api 时:

CLLocation* pa = [[CLLocation alloc] initWithLatitude:40.716715 longitude:-74.033907];
CLLocation* pa2 = [[CLLocation alloc] initWithLatitude:40.716300 longitude:-74.033900];
CLLocationDistance dist = [pa distanceFromLocation:pa2];

结果是 46.0888946842423

自己的实现

double dinstance_m(double lat1, double long1, double lat2, double long2)
 double dlong = (long2 - long1) * d2r;
 double dlat = (lat2 - lat1) * d2r;
 double a = pow(sin(dlat/2.0), 2) + cos(lat1*d2r) * cos(lat2*d2r) * pow(sin(dlong/2.0), 2);
 double c = 2 * atan2(sqrt(a), sqrt(1-a));
 double d = 6367 * c;

return d * 1000.;

结果是 46.120690774231

Oracle 的实现显然是错误的,但我不明白为什么。任何帮助将不胜感激。

【问题讨论】:

【参考方案1】:

尝试颠倒纵坐标的顺序,如下所示:

SELECT sdo_geom.sdo_distance(sdo_geom.sdo_geometry(2001, 8307, sdo_geom.sdo_point_type(-74.033907, 40.716715, NULL), NULL, NULL),
                           sdo_geom.sdo_geometry(2001, 8307, sdo_point_type(-74.033901, 40.716300, NULL), NULL, NULL), 0.0001, 'unit=M') distance_in_m
                           from DUAL;

我得到 46.087817955912。

使用 SDO_GEOMETRY,纵坐标按 X、Y(经度、纬度)顺序列出。

【讨论】:

以上是关于如何使用 Oracle 的 sdo_distance的主要内容,如果未能解决你的问题,请参考以下文章

如何查看oracle失效的索引

如何使用oracle的DBMS

如何使用oracle提供的SQL

linux下如何使用oracle自定义的实例

如何使用Oracle的游标?

如何使用Oracle跟踪文件?