mysql 根据经纬度计算距离

6378.138 * 2 * ASIN(
		SQRT(
			POW( SIN( ( : wd * PI( ) / 180-pa.wd * PI( ) / 180 ) / 2 ), 2 ) + COS( : wd * PI( ) / 180 ) * COS( pa.wd * PI( ) / 180 ) * POW( SIN( ( : jd * PI( ) / 180-pa.jd * PI( ) / 180 ) / 2 ), 2 ) 
		) 
	) AS juli
  1. 6378.138:这是地球的平均半径,单位是千米(km)。注意,这个值是一个近似值,并且地球的实际半径会因为纬度和海拔的变化而略有不同。
  2. ASIN(...):这是反正弦函数(Arcsine),用于从正弦值计算角度。
  3. SQRT(...):这是平方根函数,用于计算平方根。
  4. POW(..., 2):这是幂函数,用于计算数值的平方。
  5. SIN(...) 和 COS(...):这些是三角函数,分别表示正弦和余弦。
  6. :wd 和 :jd:这些是SQL参数或变量,分别代表给定的经度(west longitude)和纬度(north latitude)。
  7. pa.wd 和 pa.jd:这些可能是数据库表pa中的字段,代表另一个点的经度和纬度。
  8. PI():这是圆周率π的函数。

现在,我们来看看Haversine公式的核心部分:

POW( SIN( ( : wd * PI( ) / 180-pa.wd * PI( ) / 180 ) / 2 ), 2 ) +   
COS( : wd * PI( ) / 180 ) * COS( pa.wd * PI( ) / 180 ) *   
POW( SIN( ( : jd * PI( ) / 180-pa.jd * PI( ) / 180 ) / 2 ), 2 )

这部分计算了两个点之间的“大圆角”(Great-Circle Angle),它是通过比较两个点的经纬度差异来得到的。然后,这个角度被用于计算两点之间的实际距离。

最终,这段代码通过乘以地球的平均半径和应用反正弦函数,得到了两个地理坐标点之间的近似距离(以千米为单位),并将其命名为juli

注意:虽然Haversine公式在大多数情况下都足够准确,但对于非常长的距离或需要高精度的情况,可能需要使用更复杂的算法或模型。

相关推荐

  1. mysql 根据经纬度计算距离

    2024-06-05 23:14:08       23 阅读
  2. php 根据位置的经纬度计算距离

    2024-06-05 23:14:08       25 阅读
  3. php根据用户地址获取经纬度

    2024-06-05 23:14:08       33 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-05 23:14:08       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-05 23:14:08       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-05 23:14:08       82 阅读
  4. Python语言-面向对象

    2024-06-05 23:14:08       91 阅读

热门阅读

  1. MFC 用Imm类库实现输入法修改输入模式

    2024-06-05 23:14:08       31 阅读
  2. N叉树的层序遍历-力扣

    2024-06-05 23:14:08       31 阅读
  3. apex代码发送邮件时进行抄送

    2024-06-05 23:14:08       29 阅读
  4. C#语言进阶(二)—事件 第二篇(.net标准事件模型)

    2024-06-05 23:14:08       35 阅读
  5. C#面:.NET Remoting 的⼯作原理是什么

    2024-06-05 23:14:08       28 阅读
  6. 6.13 CO-RE(Compile Once – Run Everywhere)简介

    2024-06-05 23:14:08       31 阅读
  7. Github 2024-05-29 开源项目日报Top10

    2024-06-05 23:14:08       28 阅读
  8. Mysql常见日志作用

    2024-06-05 23:14:08       23 阅读
  9. 致远V8.0集成帆软10版本部署教程

    2024-06-05 23:14:08       75 阅读