Revision 9403
Added by Aaron Marcuse-Kubitza over 11 years ago
planning/workflow/validation/GeoDistKM.sql.txt | ||
---|---|---|
1 |
mailto:bboyle@email.arizona.edu/Brad_Boyle/2013-5-16/BIEN+DB+meeting+outstanding+issues |
|
2 |
--- |
|
3 |
1) I finally found the missing function geodistkm. I implemented it directly as a stored function in database geoscrub in MySQL on nimoy: |
|
4 |
|
|
5 |
mysql> show function status like "geodist%"; |
|
6 |
+----------+-----------+----------+-----------------+---------------------+---------------------+---------------+---------+----------------------+----------------------+--------------------+ |
|
7 |
| Db | Name | Type | Definer | Modified | Created | Security_type | Comment | character_set_client | collation_connection | Database Collation | |
|
8 |
+----------+-----------+----------+-----------------+---------------------+---------------------+---------------+---------+----------------------+----------------------+--------------------+ |
|
9 |
| geoscrub | GeoDistKM | FUNCTION | admin@localhost | 2011-09-23 17:14:24 | 2012-07-24 19:01:55 | DEFINER | | latin1 | latin1_swedish_ci | latin1_swedish_ci | |
|
10 |
+----------+-----------+----------+-----------------+---------------------+---------------------+---------------+---------+----------------------+----------------------+--------------------+ |
|
11 |
1 row in set (0.01 sec) |
|
12 |
|
|
13 |
mysql> show create function GeoDistKm; |
|
14 |
+-----------+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+--------------------+ |
|
15 |
| Function | sql_mode | Create Function | character_set_client | collation_connection | Database Collation | |
|
16 |
+-----------+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+--------------------+ |
|
17 |
| GeoDistKm | | CREATE DEFINER=`admin`@`localhost` FUNCTION `GeoDistKm`( lat1 FLOAT, lon1 FLOAT, lat2 FLOAT, lon2 FLOAT ) RETURNS float |
|
18 |
BEGIN |
|
19 |
DECLARE pi, q1, q2, q3 FLOAT; |
|
20 |
DECLARE rads FLOAT DEFAULT 0; |
|
21 |
SET pi = PI(); |
|
22 |
SET lat1 = lat1 * pi / 180; |
|
23 |
SET lon1 = lon1 * pi / 180; |
|
24 |
SET lat2 = lat2 * pi / 180; |
|
25 |
SET lon2 = lon2 * pi / 180; |
|
26 |
SET q1 = COS(lon1-lon2); |
|
27 |
SET q2 = COS(lat1-lat2); |
|
28 |
SET q3 = COS(lat1+lat2); |
|
29 |
SET rads = ACOS( 0.5*((1.0+q1)*q2 - (1.0-q1)*q3) ); |
|
30 |
RETURN 6378.388 * rads; |
|
31 |
END | latin1 | latin1_swedish_ci | latin1_swedish_ci | |
|
32 |
+-----------+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+--------------------+ |
|
33 |
1 row in set (0.00 sec) |
|
34 |
--- |
Also available in: Unified diff
added planning/workflow/validation/GeoDistKM.sql.txt