专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

mysql 子查询 排序,mysql中如何按距离排序筛选商家_数据库

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/5 13:22:28       共计:3579 浏览
mysql 子查询 排序,mysql中如何按距离排序筛选商家?

现在很多系统的一些功能都是基于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))))以上就是我的观点,对于这个问题大家是怎么看待的呢?欢迎在下方评论区交流 ~ 我是科技领域创作者,十年互联网从业经验,欢迎关注我了解更多科技知识!

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:mysql 更新查询结果,MySQL如何优化大分页查询_数据库 | ·下一条:mysql 查询条件日期,MySQL系统查询条件的子查询条件中包含了主表字段_数据库

Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有