mysql 计算两点之间距离

news2024/11/27 9:31:46

先说一下我们可能会用到的一些场景,这样同学们可以先评估,该篇文章是否对你有帮助!

场景:

假设 美团,我点外卖时,系统会让我先进行定位,比如我定位在了 A 点,系统就会给我推荐,离 A 点最近的商家们,我们先排除评分等等条件,只看距离,优先距离(最近的商家)。

所以这个时候,就需要用到"两点之间的距离"来处理

多分享一点:

曾经我的解决方案是这样的:请求"腾讯位置服务",他们里面有 Web端的 JavaScript ,也有服务端的 API,就可以解决我们的一些问题。

但是后来,有一次甲方的需求是:希望能匹配最近的商家,按距离从小到大显示!

用以前的经验来讲,直接拿"腾讯位置服务"里面的 API 来用,就可以满足的,但是我想了一下,在程序的性能上,这并不是一个比较好的方案,所以我就思考了一下,一定有着我还未了解到的知识,有更好的方法,所以我先上网上浏览,最终找到了,mysql 有 "geometry"数据类型

"geometry" 是 几何 的意思

同学们想一下数学上,应该就能明白了。

我们依然要使用到 经纬度 来存储

按照以往,经度、纬度,我们可能都是分开存储的,在一些场景下,就好像上面说的,我们使用 "腾讯位置服务" 时,也就需要用到 经纬度。

而这里,我们额外创建了一个字段,数据类型为"geometry",

存储的值,是这样的。它必须要这样存储,才能使用相关的函数 查出对比的位置来!

而存储时,这并不是一个存 字符串,也是需要使用到一个函数来进行存储的: ST_GeomFromText

INSERT INTO table ( `lng`, `lat`, `lng_lat`) VALUES	('104.068544', '30.606452', ST_GeomFromText ( 'POINT(104.068544 30.606452)' ));

请要注意的是, "ST_GeomFromText" 里面还使用到了 "POINT"

只有这样,该字段类型存储的值,才能成功,并且可以使用后续的函数来查找距离。

我这边常用的函数是:

st_distance_sphere  计算出来的距离,单位是"米"

我这边就拿一个实际位置来做演示吧!

查询的 SQL 如下:

select site_name,st_distance_sphere(POINT(104.068544,30.606452),lng_lat) as distant from table_name

可以看到,因为我的 查询 经纬度,直接用的是 "成都南站站点",所以得出的结果就是 "0"米,就是代表原地!

而成都北站,则距离 成都南站 约为 "10097.7070"米,换算过来大概是:"10.10"千米(公里)。

我这边使用 "高德地图" 查询了一下,"火车南站(地铁站)" 距离 "火车北站(地铁站)"

驾车模式:约为 11 公里;

骑行(电动车、自行车)模式:约为 11.4 公里;

步行模式:约为 11.2 公里

首先,确实是没有达到百分百的准确,我认为是有两个点

1. 我的数据库中存储的 成都南站 和 高德地图中的 "成都南站(地铁站)" 应该不是百分百完美匹配的,就是说不是相同的一个 经纬度。

2. 官方的计算本身就是一个约值,并非全等值,因为这里涉及到圆周率"π",π 又为 3.1415926...

综合上述我的假设,所以我认为,最终就是相差1公里左右吧!如果第一点,能确定 高德地图 和 数据库中的 经纬度完全匹配,那么问题应该不大。这个可以放给同学们去实验!

为什么我这里不直接去高德扒一个经纬度一样的存储在数据库呢,一是这个经纬度是同事存储的,二是同事应该是用的腾讯地图,三是因为我以前做这一块的时候,相差一般都是几百米,偏差不会太大,所以我觉得差不多。

所以按照上述的,我们就可以得出 "distant" 字段的大小值了,就可以进行一个排序,做到 商家离我们最近的排序在最前面。。。。

扩展:

st_distance_sphere 确实是比较好用的,但有时考虑到 mysql 的版本,扩展等原因,所以如果出现 "st_distance_sphere " 这个方法不存在时,那么用不了这个方法时,我们又该如何是好呢?

那这个时候,就可以用到另外一个方法:st_distance

可以对比出 "st_distance" 、 "st_distance_sphere ",前面是一样的。

而 st_distance 也是比较好用的,只不过需要注意的是,这个方法,计算出来的结果单位,是"",而不是"米"了。

没错,就是 圆 的 度!因为地球是圆的

所以我们还要用到 圆周率 "π",还有地球的半径

我们假设:

地球半径:6371.393千米

π:3.14159265359

180度

因为 st_distance 计算出来的结果单位是"度",所以我们要转为"米",所以就要这样:

需要乘111201(地球半径6371.393*PI/180)将值转化为米

所以 SQL 就是:

select site_name,st_distance(POINT(104.068544,30.606452),lng_lat)*111201 as distant from sp_site_config

结果为:

可以发现,两者相差的位置,其实并不远,我算了一下:

10102.1855  - 10097.707 = 4.4785

相差 4米左右,所以问题也不大!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/940566.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

八路参考文献:[八一新书]许少辉.乡村振兴战略下传统村落文化旅游设计[M]北京:中国建筑工业出版社,2022.

八路参考文献:[八一新书]许少辉.乡村振兴战略下传统村落文化旅游设计[M]北京:中国建筑工业出版社,2022.

多商户门店会员卡充值收款营销公众号开发

多商户门店会员卡充值收款营销公众号开发 一、功能特色: 专注于收款码支持商户入驻功能,降低运营成本资金可以直接到达商户,支持微信分账方式分配佣金,完全符合支付结算相关法规充值、充次支持给赠值设置有效期,促进…

防雷浪涌保护器选型方案

防雷浪涌保护器是一种用于保护电气设备免受雷电或其他电源干扰引起的过电压或过电流的装置。防雷浪涌保护器的选型应根据国家标准、设备要求和实际工程条件进行,以达到既满足防雷验收要求,又能有效保护设备的目的。地凯科技介绍一些常用的防雷浪涌保护器…

论文解读 | OmniObject3D:用于逼真感知、重建和生成的大词汇量3D对象数据集

原创 | 文 BFT机器人 这篇论文的主要目标是介绍和探索OmniObject3D数据集,该数据集包含大量真实扫描的3D物体,涵盖了190个类别,提供了多种丰富的注释,包括纹理3D网格、采样点云、多视图图像等。作者将OmniObject3D应用于多个3D视…

mysql和mybatisPlus实现:datetime类型的字段范围查询

前提说明 数据库在存储数据时,我们为了精确一下时间,便会把改时间类型的字段设置为datetime类型; 在过滤数据库数据时,我们又需要对该字段进行一个范围的过滤 由此,便出现了这篇博客 datetime数据类型 在MySQL中,datetime数据类型用于保存日期和时间的值。它的格式为Y…

ChatGPT 制作可视化柱形图突出显示第1名与最后1名

对比分析柱形图的用法。在图表中显示最大值与最小值。 像这样的动态图表的展示只需要给ChatGPT,AIGC,OpenAI 发送一个指令就可以了, 人工智能会快速的写出HTML与JS代码来实现。 请使用HTML,JS,Echarts完成一个对比分析柱形图,在图表中突出显示第1名和最后1名用单独一种不…

局域网远程软件Radmin

Radmin是一个快速且安全的远程控制和远程访问软件,通过它可以就像坐在远程计算机前一样,在远程计算机上工作,并可以从多个位置访问远程计算机。(本例使用的版本是Radmin 3.5) 下载Radmin 3.5安装包。 Radmin 3.5安装…

通信原理板块——基础知识(三)

微信公众号上线,搜索公众号小灰灰的FPGA,关注可获取相关源码,定期更新有关FPGA的项目以及开源项目源码,包括但不限于各类检测芯片驱动、低速接口驱动、高速接口驱动、数据信号处理、图像处理以及AXI总线等 7、能量信号的频谱密度 (1)能量信号…

直播时代下的海外网红营销:挑战与机遇并存

随着科技的迅猛发展,互联网正在以前所未有的速度改变着人们的生活方式和商业模式。其中,直播和网红营销作为数字时代的新生力量,迅速崛起并引领着市场的潮流。特别是在海外市场,直播时代为海外网红营销带来了前所未有的机遇和挑战…

ThinkPHP 通用的API格式封装

ThinkPHP 通用的API格式封装 1.创建status.php 用于设置通用的状态码返回枚举类2.将API返回格式统一封装3.重写BaseController中的__call方法4.在控制器下面新建Error控制器&#xff0c;然后添加__call方法 1.创建status.php 用于设置通用的状态码返回枚举类 <?phpreturn[…

[Agent]开发---ConversationalRetrievalAgent开发

参考资料[langchain官方文档]&#xff1a; tool retrieval agent::::https://python.langchain.com/docs/modules/agents/how_to/custom_agent_with_tool_retrieval retrieval memory:::https://python.langchain.com/docs/modules/memory/types/vectorstore_retriever_memory …

科技巨擘:探索中国机器人产业的腾飞之路

原创 | 文 BFT机器人 引言 今年4月&#xff0c;特斯拉宣布在德州建造全球最大的电池工厂&#xff0c;这一举措进一步实现了马斯克对于“机器制造机器”的大目标。这座工厂不像过去依靠传统的工人模式&#xff0c;而是采用大量机器人完成生产任务。 机器人已成「刚需」。 机器人…

Mybatis小记

目录 Mybatis第一个程序 xml文件 测试类 错误排查 Mybatis第一个程序 1.搭建实验数据库 2.导入MyBatis相关jar包 3.编写MyBatis核心配置文件 4.编写MyBatis工具类 5.创建实体类、 6.编写Mapper接口类 7.编写Mapper.xml配置文件 8.编写测试类 对象传参只引用需要的属性就可…

突破连接壁垒,火山引擎边缘云网络的先行之路

在万物互联时代&#xff0c;信息不局限于人与人之间的交流&#xff0c;大量的机器设备也需要进行信息交流。就在去年&#xff0c;我国率先迎来了“物超人”的历史性时刻&#xff0c;即物联网连接数超越了人联网连接数。边缘云的发展进入到“黄金十年”。 “要致富&#xff0c;…

多线程(一)

一.什么是线程 一个线程就是一个执行流&#xff0c;多个线程就是多个执行流&#xff0c;多线程就是让多个执行流分别执行自己的代码。 比如&#xff1a;利用多线程在控制台上循环交替打印A和B package demo; public class Main {static class SubThread extends Thread{Over…

Webgl利用缓冲区绘制三角形

什么是attribute 变量 它是一种存储限定符&#xff0c;表示定义一个attribute的全局变量&#xff0c;这种变量的数据将由外部向顶点着色器内传输&#xff0c;并保存顶点相关的数据&#xff0c;只有顶点着色器才能使用它 <!DOCTYPE html> <html lang"en"&g…

Blender界面学习02

学习视频 【基础篇】1.3 认识界面_哔哩哔哩_bilibili 基本的3d建模的流程是什么&#xff1f; 四个角现出加号时可以拆分窗口&#xff0c;也可以合并窗口 向自己的方向拉是合并&#xff0c;向不是自己的方向拉是合并 如果界面搞乱后需要回到原来的布局 然后在新建的布局上右击 …

CSRF漏洞场景复现

文章目录 CSRF漏洞是什么&#xff1f;场景复现get方式攻击post方式攻击 原理分析 CSRF漏洞是什么&#xff1f; 跨站请求伪造(Cross Site Request Forgery&#xff0c;CSRF)是一种攻击&#xff0c;它强制浏览器客户端用户在当前对其进行身份验证后的Web 应用程序上执行非本意操作…

手把手教你用R优雅地绘制研究区地图

用R语言绘制研究区图和地图 引言 在地理信息系统和数据可视化领域&#xff0c;绘制研究区图和地图是非常重要的任务。R语言是一种功能强大的统计分析和可视化工具&#xff0c;也可以用于绘制各种类型的地图。本文将介绍如何使用R语言绘制研究区图和地图。 准备工作 在使用R语…

skywalking agent监控java服务

一、前言 skywalking agent可以监控的服务类型有多种&#xff0c;python、go、java、nodejs服务等都可以监控&#xff0c;现在通过java服务来演示skywalking agent的使用&#xff0c;并且是使用容器的方式实现 二、部署skywalking agent监控 需要注意&#xff0c;skywalking…