当前位置: 首页 > news >正文

mysql 计算两点之间距离

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

场景:

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

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

多分享一点:

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

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

用以前的经验,直接拿"腾讯位置服务"里面的 API 来用,就可以满足的,但是我想了一下,在程序的性能上,这并不是一个比较好的方案,因为可能会遇到循环,我要将商家逐个的传过去,再拿到"腾讯位置服务"返回给我的结果,无论用不用循环,我都要将 N 个商家拿去请求外网,也还是会请求很多次,性能上也是一笔很大的开销!

并且,人家第三方提供的 API 免费次数是有限的,这里划重点!

所以我就思考了一下,一定有着我还未了解到的知识,有更好的方法,所以我去网上浏览,最终找到了,mysql 有 "geometry"数据类型,可以达到我的预期。

"geometry" 是 几何 的意思

在 MySQL 中,Geometry 等几何对象可以用来表示地理位置,即用几何对象表示地理空间数据。

在 MySQL 中支持的几何数据类型包括 Geometry、Point、LineString、Polygon 以及集合类型的 MultiPoint、MultiLineString、MultiPolygon、GeometryCollection。其中 Geometry 可以表示任意一种几何类型,即在 MySQL 中,如果一个字段类型是 Geometry,则可以存储 Point、LineString 等其它几何类型的值。其他的几种则需要固定有效的表示格式。

在MySQL中有3种表达几何对象的格式:

1. WKT(文本格式)

2. WKB(二进制格式)

3. MySQL 内部存储格式

WKT 是文本格式,因此可以直接使用文本来表示几何数据,实现数据的插入与编辑

小tips:我们本期 会涉及到数学上的一些计算

首先,可以看一下数据表:

上图,按照以往我这边一定是存在着 "经度"、"纬度" 两个字段的,因为传给 "腾讯" 或 "阿里" 等第三方处理,都是需要使用到 经纬度的。

而本次,我们可以自己在内部使用 mysql 自带的方法,就可以计算出结果。

所以我们追加了一个字段 "lng_lat",该字段的数据类型则为:geometry

上图,是 geometry 类型存储的值。它必须要这样存储,才能使用相关的方法 查出对比的位置来!

而存储时,这里并不是一个单纯的"字符串"数据,也是需要使用到一个方法来进行存储的: ST_GeomFromText

ST_GeomFromText: 用于将几何数据从可读的文本类型转换成内部存储的二进制类型

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

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

"POINT" 代表一个点

所以我们理解为,计算时,就是"点与点之间的距离"

我们还需要注意一点:

只有 Point 中存储的是经纬度即第一第二坐标范围分别在 (-180,180) 与 (-90,90) 内时才可以转换成功

常用的方法是:

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

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

查询的 SQL 如下:

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

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

st_distance_sphere(POINT(104.068544,30.606452),lng_lat)

上面的 104.068544,30.606452,就是我们的位置,我是直接拿 库中 "成都南站"的位置直接使用的,所以得出的结果,成都南站 和我的位置,相差为 0 米

同学可以这样理解:现在数据库里有 N 个商家,也都存好位置了,现在我们作为 用户(消费者) 需要找到最近商家,那么就需要先进行定位,定位后就会有经纬度,这时候将我们的经纬度 替换 上面的 "104.068544,30.606452" 就可以了

而成都北站,则距离 成都南站 约为 "10097.707"米,换算过来约为:"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_sphere:该函数的计算结果要比使用 st_distance 再转换为米的结果更精确。不过该函数是 MySQL5.7 之后才引入的,5.7 之前还是需要通过计算转换成米

st_distance:该函数计算出来的结果单位,是"",而不是"米"。

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

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

我们假设:

地球半径:6371000米

π:3.1415926

圆的 180 度

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

最后的结果 乘 111195 将值转化为米

111195 的由来:地球半径 6371000*PI/180

所以 SQL 就是:

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

结果为:

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

10101.64  - 10097.7 = 3.94

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

相关文章:

mysql 计算两点之间距离

先说一下我们可能会用到的一些场景,这样同学们可以先评估,该篇文章是否对你有帮助! 场景: 假设 美团,我点外卖时,系统会让我先进行定位,比如我定位在了 A 点,系统就会给我推荐&…...

c语言自定义头文件是什么情况下使用?一般在什么情况下引用自定义的头文件?一般在自定义头文件中写什么代码?

c语言自定义头文件是什么情况下使用?一般在什么情况下引用自定义的头文件?一般在自定义头文件中写什么代码? C语言自定义头文件是一种用来封装函数和变量声明的文件,它通常用于将一组相关的函数和变量的声明集中在一个地方&#…...

electron应用打包成功纪念一下

electron应用打包成功纪念一下,以前曾经行过后来打包各种报错,现在有空就尝试解决一下 首先安装nvm能够方便切换node版本 curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.34.0/install.sh | bash 顺利安装后你用nvm list查看node列表时会…...

远程办公中安全远程访问解决方案

什么是安全远程访问 安全的远程访问是一个至关重要的过程,可让您使用互联网从远处完全控制某人的设备。为了确保安全,为受保护的远程访问采取了额外的身份验证和加密措施。 为什么安全远程访问解决方案很重要 当 IT 技术人员从远处帮助人们解决计算机…...

StartUp启动框架-Android启动性能

简述 当谈论Android应用程序的启动性能时,StartUp启动框架是一个不可忽视的关键工具。它旨在优化应用程序的启动过程,确保用户在打开应用时能够迅速获得流畅、高效的体验。让我们来深入了解StartUp框架的作用和重要性,以及它是如何改善Andro…...

Positive Technologies:五分之四的网络攻击具有针对性

Positive Technologies 对 2023 年第二季度的相关网络威胁进行了分析。报告显示,自今年年初以来,有针对性的攻击数量增加了 10%,目前占 78%。专家们注意到利用漏洞的大规模攻击和大量用户个人数据的泄露。此外,在此期间&#xff0…...

clickhouse的另类表引擎

clickhouse常用的MergeTree引擎外,还有特殊的引擎 1,memory引擎,顾名思义,数据是存储在内存中,数据不会被压缩也不会倍格式化转换数据在内存中保存的形态与查询时看到的如出一辙,重启ck数据丢失 2&#xff…...

Uniapp新版本打包后覆盖安装,新增的页面无法跳转,需退出重新启动才可以打开的解决方案

最近写uniapp项目,发现一个坑,在新版本覆盖安装后直接打开APP,新增的页面竟然无法跳转,需要重新启动才可以正常打开,在网上查了很多方法,最终总结下来有以下几点: 1.看打的是debug包还是releas…...

系统架构设计高级技能 · 面向服务架构设计理论与实践

点击进入系列文章目录 系统架构设计高级技能 面向服务架构设计理论与实践 一、SOA的相关概念1.1SOA的定义1.2 业务流程与业务流程执行语言 二、SOA的发展史三、SOA与微服务的区别三、SOA的参考架构四、SOA的主要协议规范五、SOA的设计标准要求六、SOA的作用与设计原则七、SOA的…...

QT注册界面练习(信号与槽实现页面跳转)

一、注册界面练习思路以及具体代码 在完成注册页面搭建的前提下,通过信号与槽机制实现多组件之间的相互通信,实现页面跳转。 基本步骤: 首先,将注册页面的登录按钮与成功登陆信号绑定,当用户名与密码均匹配时&#xf…...

MySQL从入门到精通【进阶篇】之 主从复制详解

文章目录 0.前言1. 主从复制简介2. 主从复制的工作流程主从复制过程中的日志文件作用(Binary Log)和中继日志(Relay Log) 3. MySQL主从复制的配置4. 参考资料 0.前言 MySQL的主从复制和读写分离是数据库领域的基本概念&#xff0…...

vue使用qrcodejs2生成二维码

目录 概要 构建展示的vue组件qrcode.vue 组件的使用 概要 项目中用到需要展示二维码的样式&#xff0c;想到了qrcode 例如&#xff1a; 前提&#xff1a;安装包 npm install qrcodejs2 --save 构建展示的vue组件qrcode.vue <template><div style"width: …...

python注释

任何编程语言都少不了注释&#xff0c;Python也不例外&#xff0c;以下是Python注释的具体用法&#xff1a; 单行注释 Python编程语言的单行注释常以#开头&#xff0c;单行注释可以作为单独的一行放在被注释代码行之上&#xff0c;也可以放在语句或者表达式之后。 实例&…...

update-alternatives详解

1.功能作用 update-alternatives是dpkg的实用工具&#xff0c;用来维护系统命令的符号链接&#xff0c;以决定系统默认使用什么命令。 在Debian系统中&#xff0c;我们可能会同时安装有很多功能类似的程序和可选配置&#xff0c;如Web浏览器程序(firefox&#xff0c;konquero…...

JavaScript 编写更好的条件语句

在任何编程语言中&#xff0c;代码需要根据不同的条件在给定的输入中做不同的决定和执行相应的动作。 例如&#xff0c;在一个游戏中&#xff0c;如果玩家生命点为0&#xff0c;游戏结束。在天气应用中&#xff0c;如果在早上被查看&#xff0c;显示一个日出图片&#xff0c;如…...

聊聊PBE算法

序 本文主要研究一下PBE算法 PBE PBE即Password Based Encryption&#xff0c;基于口令的加密&#xff0c;它是一种组合算法&#xff0c;即一般是哈希对称算法&#xff0c;比如PBEWithMD5AndDES&#xff0c;就是用MD5做哈希&#xff0c;用DES做加解密&#xff0c;而其密钥则…...

用MFC打开外部程序

在MFC&#xff08;Microsoft Foundation Classes&#xff09;中&#xff0c;你可以使用ShellExecute函数来打开Notepad并加载指定的文件。ShellExecute函数是Windows API的一部分&#xff0c;它可以执行与操作系统相关的操作&#xff0c;例如打开文件、运行程序等。 以下是在M…...

基于全新电脑环境安装pytorch的GPU版本

前言&#xff1a; 距离第一次安装深度学习的GPU环境已经过去了4年多&#xff08;当时TensorFlow特别麻烦&#xff09;&#xff0c;现在发现安装pytorch的GPU版本还是很简单方便的&#xff0c;流程记录如下。 安装步骤&#xff1a; 步骤一&#xff1a;官网下载Anaconda Free…...

[当前就业]2023年8月25日-计算机视觉就业现状分析

计算机视觉就业现状分析 前言&#xff1a;超越YOLO&#xff1a;计算机视觉市场蓬勃发展 如今&#xff0c;YOLO&#xff08;You Only Look Once&#xff09;新版本的发布周期很快&#xff0c;每次迭代的性能都优于其前身。每 3 到 4 个月就会推出一个升级版 YOLO 变体&#xf…...

虚拟化技术原理

计算虚拟化 介绍 把物理主机上物理资源&#xff08;CPU&#xff0c;内存&#xff0c;IO外设&#xff09;&#xff0c;通过虚拟化层抽象成超量、等量的逻辑资源&#xff08;虚拟CPU&#xff0c;虚拟内存&#xff0c;虚拟IO设备&#xff09;&#xff0c;然后重新组合形成新的虚…...

BatchNorm实战避坑指南:为什么你的小批量训练总是不稳定?

BatchNorm实战避坑指南&#xff1a;小批量训练不稳定的深层解析与解决方案 1. 问题背景&#xff1a;为什么小批量训练总是不稳定&#xff1f; 在深度学习实践中&#xff0c;Batch Normalization&#xff08;批归一化&#xff09;已成为许多模型架构的标准组件。然而&#xff0c…...

保姆级教程:用ESP-IDF Monitor和Heap Tracing给LVGL任务栈“拍个X光”

ESP32-S3深度调试&#xff1a;用Heap Tracing与Monitor透视LVGL内存瓶颈 当LVGL动画在ESP32-S3上随机崩溃时&#xff0c;大多数开发者会本能地调整栈大小参数——这就像给发烧病人直接开退烧药&#xff0c;却不去检查感染源。本文将带您使用ESP-IDF的专业诊断工具&#xff0c;…...

SpringBoot项目整合Redisson实战:从连接池报错到Redis集群健康检查的完整避坑指南

SpringBoot整合Redisson深度实践&#xff1a;连接池优化与集群健康监控全解析 Redis作为分布式系统的核心组件&#xff0c;其Java客户端Redisson的高阶用法一直是开发者关注的焦点。去年某电商平台大促期间&#xff0c;因Redis集群节点闪断导致的分布式锁失效事故&#xff0c;让…...

手把手教你用LVGL 8.x实现一个会变色的电池电量控件(附完整代码)

从零构建LVGL 8.x动态电池控件&#xff1a;变色逻辑与分辨率适配实战 在智能手表、医疗设备等嵌入式场景中&#xff0c;电池电量的可视化展示从来都不只是简单的数字堆砌。想象一下&#xff0c;当用户瞥见设备屏幕时&#xff0c;一个会随着电量降低逐渐由绿转红的电池图标&…...

Unity Input System手势识别避坑指南:为什么你的双指缩放总是不跟手?

Unity Input System手势识别避坑指南&#xff1a;为什么你的双指缩放总是不跟手&#xff1f; 当你在Unity中实现双指缩放功能时&#xff0c;是否遇到过这样的问题&#xff1a;用户手指明明在屏幕上流畅滑动&#xff0c;但画面却像卡顿了一样&#xff0c;或者缩放比例突然跳变&a…...

【仅限核心开发者知晓】Polars 2.0清洗Pipeline的4层IR抽象:为何比Pandas快11.8倍?源码注释级解读

第一章&#xff1a;Polars 2.0清洗Pipeline的演进本质与性能跃迁全景Polars 2.0 将清洗 Pipeline 从“惰性执行显式优化提示”升级为“全图级自动重写零拷贝流式调度”&#xff0c;其本质是将数据清洗从过程式编排转向声明式语义图推理。核心突破在于 LazyFrame 的物理计划生成…...

倩女幽魂易语言源码|支持编译运行,适合易语言开发者学习研究

温馨提示&#xff1a;文末有联系方式【标一】可编译倩女幽魂易语言源码开放 本套源码基于易语言开发&#xff0c;已完成基础环境配置与编译测试&#xff0c;生成的程序可正常启动并执行核心逻辑。 适用于熟悉易语言语法、掌握API调用与内存读写技术的开发者。【标二】仅面向具备…...

如何让AI成为你的第二大脑?AnythingLLM浏览器扩展使用指南

如何让AI成为你的第二大脑&#xff1f;AnythingLLM浏览器扩展使用指南 【免费下载链接】anything-llm 这是一个全栈应用程序&#xff0c;可以将任何文档、资源&#xff08;如网址链接、音频、视频&#xff09;或内容片段转换为上下文&#xff0c;以便任何大语言模型&#xff08…...

如何永久保存微信聊天记录:3步实现数据自主管理的完整指南

如何永久保存微信聊天记录&#xff1a;3步实现数据自主管理的完整指南 【免费下载链接】WeChatMsg 提取微信聊天记录&#xff0c;将其导出成HTML、Word、CSV文档永久保存&#xff0c;对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/W…...

AtlasOS终极指南:专业解决Windows安装错误2502/2503的完整方案

AtlasOS终极指南&#xff1a;专业解决Windows安装错误2502/2503的完整方案 【免费下载链接】Atlas &#x1f680; An open and lightweight modification to Windows, designed to optimize performance, privacy and security. 项目地址: https://gitcode.com/GitHub_Trendi…...