java Mysql 根据经纬度实时计算地址位置距离
2022/5/10 19:00:44
本文主要是介绍java Mysql 根据经纬度实时计算地址位置距离,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
数据库地址表设计
- 通用的区域街道地址表
tz_sys_area
字段名称 | 类型 | 备注 |
---|---|---|
area_id | bigint | 区域 ID |
area_name | varchar(32) | 区域名称 |
parent_id | bigint | 所属父区域 ID |
level | int | 层级 |
type | char | 区域类型 0 国家 1 省份直辖市 2 地市 3 区县 |
area_name | varchar(32) | 区域名称 |
parent_id | bigint | 所属父区域 ID |
level | int | 层级 |
后台也可以做修改
四级区域地址数据
来源我在网上找的 json 文件然后按照格式倒入到的数据库,需要的可以关注我的公众号猿小叔
- 门店地址表
tz_address
需求实现
- 这里计算距离就需要用到
经纬度
需要使用高德地图 api 接口地理/逆地理编码
获取地址经纬度并保存
/** * 地理/逆地理编码 (java项目大全 fhadmin.cn) * https://lbs.amap.com/api/webservice/guide/api/georegeo * * @return */ public String addressToLongitude(String address) { String longitude = ""; String urlString = "?key={key}&address={address}&output=JSON"; String response = restTemplate.getForObject(ApiAction.API_GEOREGO_TEST + urlString, String.class, apiKey, address); if (StrUtil.isEmpty(response)) { return null; } JSONObject jsonObject = JSON.parseObject(response); String code = jsonObject.getString("infocode"); if (code.equals("10000")) { JSONArray jsonArray = jsonObject.getJSONArray("geocodes"); JSONObject jsonObject1 = (JSONObject) jsonArray.get(0); longitude = jsonObject1.get("location").toString(); } else { return null; } return longitude; }
private Address setlngAndLat(Address address) { String addr = address.getProvince() + address.getCity() + address.getArea() + address.getAddr(); String longitude = gaoDeService.addressToLongitude(addr); if (StrUtil.isBlank(longitude)) { throw new BusinessException("地址经纬度识别识别"); } String lat = longitude.split(",")[1]; String lng = longitude.split(",")[0]; address.setLat(lat); address.setLng(lng); return address; }
- MySQL 根据经纬度计算地址距离当前位置
SELECT ( 6371 * acos( cos(radians(#{lat})) * cos(radians(lat)) * cos(radians(lng) - radians(#{lng})) + sin(radians(#{lat})) * sin(radians(lat)) ) ) AS distance FROM tz_user_addr where addr_id=#{storeAddrId}
这篇关于java Mysql 根据经纬度实时计算地址位置距离的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23Springboot应用的多环境打包入门
- 2024-11-23Springboot应用的生产发布入门教程
- 2024-11-23Python编程入门指南
- 2024-11-23Java创业入门:从零开始的编程之旅
- 2024-11-23Java创业入门:新手必读的Java编程与创业指南
- 2024-11-23Java对接阿里云智能语音服务入门详解
- 2024-11-23Java对接阿里云智能语音服务入门教程
- 2024-11-23JAVA对接阿里云智能语音服务入门教程
- 2024-11-23Java副业入门:初学者的简单教程
- 2024-11-23JAVA副业入门:初学者的实战指南