Mysql实现经纬度距离的排序(粗略的城市排序)

一 创建省市、经纬度关系表

java 复制代码
CREATE TABLE `t_city` (
  `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
  `gmt_create` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `gmt_modified` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  `is_deleted` tinyint DEFAULT '0' COMMENT '是否删除',
  `code` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '城市编码',
  `name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMMENT '城市名称',
  `province` varchar(50) DEFAULT NULL COMMENT '省份',
  `longitude` decimal(10,6) DEFAULT NULL COMMENT '经度',
  `latitude` decimal(10,6) DEFAULT NULL COMMENT '纬度',
  PRIMARY KEY (`id`),
  KEY `idx_pro_city` (`province`,`name`) COMMENT '省市'
) ENGINE=InnoDB AUTO_INCREMENT=345 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='设备租赁';

可以将省市经纬度录入,DeepSeek就可以查到。

省市参考链接:https://raw.githubusercontent.com/modood/Administrative-divisions-of-China/master/dist/pca-code.json

https://github.com/wecatch/china_regions

https://github.com/modood/Administrative-divisions-of-China

java 复制代码
-- 使用MySQL的Haversine公式计算距离
SELECT 
   *,
    ROUND(
        6371 * 2 * ASIN(
            SQRT(
                POW(SIN(RADIANS((latitude - 39.9042) / 2)), 2) +
                COS(RADIANS(39.9042)) * COS(RADIANS(latitude)) *
                POW(SIN(RADIANS((longitude - 116.4074) / 2)), 2)
            )
        ), 2
    ) AS distance_km
FROM cities(可以替换成你的业务表)
WHERE longitude IS NOT NULL AND latitude IS NOT NULL
ORDER BY distance_km ASC, gmt_create desc
LIMIT 20;


-- 参数说明:? 依次为:目标纬度,目标纬度,目标经度
-- 例如查找距离北京市最近的20个城市
-- 参数:39.9042, 39.9042, 116.4074
相关推荐
剩下了什么13 小时前
MySQL JSON_SET() 函数
数据库·mysql·json
山峰哥13 小时前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉14 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变14 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
WangYaolove131415 小时前
基于python的在线水果销售系统(源码+文档)
python·mysql·django·毕业设计·源码
山岚的运维笔记16 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里16 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科16 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦17 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总17 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法