2013-02-05 14 views
5

मैं Oracle DB में दो अंक के बीच एक दूरी की गणना करने के लिए कोशिश कर रहा हूँ,कैसे Oracle की sdo_distance

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

उपयोग करने के लिए इस एसक्यूएल कथन का उपयोग:

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

है ऐप्पल के कोरलोकेशन एपीआई का उपयोग करते हुए इसे करते हुए:

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 के कार्यान्वयन स्पष्ट रूप से बंद है, लेकिन मैं क्यों नहीं दिख रहा है। किसी भी तरह की सहायता का स्वागत किया जाएगा।

उत्तर

5

, तालमेल के आदेश को पलटने में के रूप में प्रयास करें:

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; 

मैं ४६.०८७८१७९५५९१२ मिलता है।

SDO_GEOMETRY के साथ, ordinates एक्स, वाई (रेखांश, अक्षांश) क्रम में सूचीबद्ध हैं।

संबंधित मुद्दे