前言:
眼前姐妹们对“sql根据经纬度算距离函数”大概比较重视,看官们都需要知道一些“sql根据经纬度算距离函数”的相关文章。那么小编在网络上收集了一些关于“sql根据经纬度算距离函数””的相关文章,希望你们能喜欢,兄弟们一起来学习一下吧!本文介绍如何通过SQL语句根据经纬度计算距离。SQL语句中用到了ACOS、COS、SIN、RADIANS等SQL函数。
1、创建测试表
执行以下SQL语句创建测试表。
CREATE TABLE `test` ( `id` bigint(20) NOT NULL COMMENT '编号', `lon` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '经度', `lat` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '纬度', PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;2、插入模拟数据
执行以下SLQ创建模拟数据。
INSERT INTO `test` VALUES (1, '113.66072', '34.79977');INSERT INTO `test` VALUES (2, NULL, NULL);INSERT INTO `test` VALUES (3, '113.42175853602474', '34.811229145387216');INSERT INTO `test` VALUES (4, '113.73812176197008', '34.783202623364886');INSERT INTO `test` VALUES (5, '113.65', '34.76');INSERT INTO `test` VALUES (6, '113.65', '34.76');INSERT INTO `test` VALUES (7, '113.65', '34.76');INSERT INTO `test` VALUES (8, '113.673302', '34.804753');INSERT INTO `test` VALUES (9, '34.79977', '34.81597096304563');
执行成功后表结构数据如下。
3、根据经纬度计算距离
假设当前的位置为【113.65、34.76】,则可以通过以下SQL计算当前位置与每条记录之间的距离。
SELECT *, ACOS( COS(RADIANS(34.76)) * COS(RADIANS(lat)) * COS(RADIANS(lon) - RADIANS(113.65)) + SIN(RADIANS(34.76)) * SIN(RADIANS(lat)) ) * 6378 as distanceFROM test
执行结果如下,distance字段即为距离值,单位千米(km),如需转换为米(m),则乘以1000就行了。
版权声明:
本站文章均来自互联网搜集,如有侵犯您的权益,请联系我们删除,谢谢。
标签: #sql根据经纬度算距离函数