mysql获取附近的店并显示当前距离并由近到远显示

43 篇文章 1 订阅

 

1、创建测试数据

CREATE TABLE `store` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) NOT NULL COMMENT '商家名称',
  `address` varchar(200) NOT NULL COMMENT '商家地址',
  `coordinates` varchar(50) NOT NULL COMMENT '经纬度',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=417 DEFAULT CHARSET=utf8;

INSERT INTO `store` VALUES ('1', '店铺a', '广东省深圳市南山区大学城地铁站', '22.582096,113.965304');
INSERT INTO `store` VALUES ('2', '店铺b', '广东省深圳市南山区西丽地铁站', '22.58063,113.954406');
INSERT INTO `store` VALUES ('3', '店铺c', '广东深圳市龙华区龙华地铁站', '22.610563,114.030311');
INSERT INTO `store` VALUES ('4', '店铺d', '广东省深圳市龙华深圳北站', '22.609581,114.029225');

2、 下面是根据给定的经纬度和查询条件进行查询的SQL语句:

@lat和@lng为用户经纬度

juli单位为米

查询20公里内范围的店铺

显示近到远的店铺


SET @lat = 22.585786;
SET @lng = 113.962966;
SELECT
	xx.*
FROM
	(
		SELECT DISTINCT
			s.*, ROUND(
				6378.138 * 2 * ASIN(
					SQRT(
						POW(
							SIN(
								(
									@lat * 3.1415926 / 180 - SUBSTRING_INDEX(coordinates, ',', 1) * 3.1415926 / 180
								) / 2
							),
							2
						) + COS( @lat * 3.1415926 / 180) * COS(
							SUBSTRING_INDEX(coordinates, ',', 1) * 3.1415926 / 180
						) * POW(
							SIN(
								(
									@lng * 3.1415926 / 180 - SUBSTRING_INDEX(coordinates, ',', - 1) * 3.1415926 / 180
								) / 2
							),
							2
						)
					)
				) * 1000
			) AS juli
		
		FROM
	     store AS s
	
	) xx
WHERE
    xx.juli <= 20000;
ORDER BY  xx.juli  desc

查询结果

 以上查询语句会根据给定的经纬度(22.585786, 113.962966)计算每个店铺与给定位置的距离,并按距离降序排列。然后,从距离小于等于20km的店铺中筛选出结果。 请注意,这里我使用了变量@lat@lng来表示给定的经纬度,您可以根据实际情况进行替换。此外,表名和字段名也需要根据您的数据库结构进行相应的修改。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

PHP隔壁老王邻居

啦啦啦啦啦

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值