java之uniapp实现门店地图

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

实现查询门店地址的功能,可以按照距离排序。使用技术:java+mysql+uniapp百度地图+高德获取经纬度

提示:以下是本篇文章正文内容,下面案例可供参考

一、后台实现

1. 获取门店的经纬度

可以通过高德或者百度的api接口传入地址获取经纬度。

这里我使用的是高德,高德api文档地址

将拉取过来的经纬度存入到数据库中

sql 复制代码
CREATE TABLE `ums_member_company_coordinate` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `company_name` varchar(255) DEFAULT NULL,
  `address_detail` varchar(255) DEFAULT NULL COMMENT '详细地址\n',
  `address_province` varchar(20) DEFAULT NULL COMMENT '地址-省',
  `address_city` varchar(20) DEFAULT NULL COMMENT '地址-市',
  `address_county` varchar(20) DEFAULT NULL COMMENT '地址-县(区、市)',
	`location` point NOT NULL COMMENT '经纬度',
  PRIMARY KEY (`id`) USING BTREE,
  SPATIAL KEY `spatial_index_location` (`location`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4 COMMENT='客户门店高德坐标';

示例数据:

sql 复制代码
INSERT INTO `` (`company_name`, `address_detail`, `address_province`, `address_city`, `address_county`, `location`) VALUES ('南昌市龙盛大药房有限公司', '江西省南昌市西湖区建设西路1285号龙盛建设佳园4号楼商用楼104室', '江西省', '南昌市', '西湖区', ST_GeomFromText('POINT(115.877543 28.649779)'));
INSERT INTO `` (`company_name`, `address_detail`, `address_province`, `address_city`, `address_county`, `location`) VALUES ('江西益康大药房有限公司', '江西省南昌市西湖区云锦路436号中海朝阳郡铂宫2号楼1层商业111室(011室)', '江西省', '南昌市', '西湖区', ST_GeomFromText('POINT(115.875458 28.624109)'));

注意location 字段为point 类型,所以我们在新增或者修改数据的时候需要做处理

sql 复制代码
UPDATE set location = POINT(CAST(#{longitude} as DECIMAL(12,6)),CAST(#{latitude} as DECIMAL(12,6))) WHERE company_name = '南昌市龙盛大药房有限公司'

2.api查询对应的sql

下面传入的115.867543 和28.649779 为当前查询人的经纬度,最终的结果distance 就是距离的公里数

sql 复制代码
SELECT
	company_name,
	address_detail,
	address_province,
	address_city,
	address_county,
	location,
	ifnull(
		ROUND(
			ST_DISTANCE_SPHERE ( location, POINT ( CAST( 115.867543 AS DECIMAL ( 12, 6 )), CAST( 28.649779 AS DECIMAL ( 12, 6 ))) )/ 1000,
			2 
		),
		999999999999 
	) AS distance 
FROM
	ums_member_company_coordinate 

order by distance  asc 

二 、小程序实现

小程序需要获取到当前手机的经纬度,就是上面传入的15.867543 和28.649779,然后调用后台接口后台把结果渲染在页面上。

uniapp地图文档入口

相关推荐
Vacant Seat10 分钟前
图论-实现Trie(前缀树)
java·开发语言·数据结构·图论
猪猪虾的业余生活19 分钟前
Qt 驾校考试系统项目实现
开发语言·qt
香菇滑稽之谈21 分钟前
责任链模式的C++实现示例
开发语言·c++·设计模式·责任链模式
工一木子24 分钟前
【HeadFirst系列之HeadFirstJava】第16天之深入解析 Java 集合与泛型:高效管理数据的终极指南!(含代码实战)
java·集合·泛型
风莫寻42 分钟前
【Troubleshot】Qt 长按按键 keyPressEvent keyReleaseEvent 自动重复问题
开发语言·qt
ZC·Shou42 分钟前
Rust 之一 基本环境搭建、各组件工具的文档、源码、配置
开发语言·rust·cargo·rustc·rustup·clippy·rustfmt
Hello.Reader44 分钟前
深入理解 Rust 中的模式匹配语法
开发语言·rust
最胖的小仙女1 小时前
通过动态获取后端数据判断输入的值打小
开发语言·前端·javascript
阿波拉1 小时前
AttributeError: module ‘backend_interagg‘ has no attribute ‘FigureCanvas’问题解决
开发语言·python
Yuanymoon1 小时前
【由技及道】统一封装API返回结果后String返回报错文件解决原理--Spring 消息转换器的层次图解与规则说明【人工智障AI2077的开发问题日志002】
java·spring