期货交易自动化论坛

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 29|回复: 0

mysql中如何按距离排序筛选商家? - 比特币今日价格

[复制链接] |主动推送

285万

主题

285万

帖子

855万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
8553710
发表于 2022-9-11 09:00:17 | 显示全部楼层 |阅读模式
现在很多系统的一些功能都是基于LBS来提供服务的。什么是LBS呢,LBS是指基于地理位置的服务,通过获取用户的地理位置从而给用户提供更好的服务。比如我们使用外卖平台时可以选择离最近的商家,原理无非就是将你的位置信息和商家的位置信息进行对比,找出距离最近的位置并排序返回结果。
MySQL支持空间数据类型MySQL 5以上都是支持空间数据类型,它主要支持以下空间类型:
点:POINT
线:LINESTRING
面:POLYGON
集合:GEOMETRY,可存放点、线、面
还支持多个点、多个线、多个面的数据。
MySQL按距离查找并排序的实现思路1、字段类型选择 POINT
对于用户的位置信息我们选择POINT类型存储,将用户经度、纬度入库保存,比如下图中的pt字段。

2、通过 GLength 函数进行区间搜索
select id, pt,city from locationPoint where 0.5 = GLength(LineStringFromWKB(LineString(pt, point(113.4 ,34.46))))

以上就是我的观点,对于这个问题大家是怎么看待的呢?欢迎在下方评论区交流 ~ 我是科技领域创作者,十年互联网从业经验,欢迎关注我了解更多科技知识!
polygon平台

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|期货交易自动化论坛

GMT+8, 2024-11-29 04:44 , Processed in 0.108230 second(s), 27 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表