发布时间:2023-12-07 09:30
最近在做项目时候,遇到一个这样子的需求,
点到卡包里面卡券使用使用,需要展示卡券使用附近门店,
字段名称 | 类型 | 备注 |
---|---|---|
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文件然后按照格式倒入到的数据库
需要使用高德地图api接口地理/逆地理编码获取地址经纬度并保存
/** * 地理/逆地理编码 * 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; }
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}
到此这篇关于如何利用Mysql计算地址经纬度距离实时位置的文章就介绍到这了,更多相关Mysql计算地址经纬度内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
分库分表真的适合你的系统吗?聊聊分库分表和NewSQL如何选择
关于使用Spring Cloud Gateway网关网络连接的4个重要的参数配置
seaborn.load_dataset报错URLError: <urlopen error [WinError 10060] 由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败。>
(JavaWeb)会话跟踪技术Cookie和Session(重点)
Deep Neural Networks for Learning Graph Representations——paper 笔记
HarmonyOS和iOS,鸿蒙系统再受质疑 鸿蒙HarmonyOS 2.0与安卓/ios的区别