Springboot实战——黑马点评之附近商铺

news/2024/11/15 16:14:52/文章来源:https://www.cnblogs.com/Wyuf1314/p/18423085

Springboot实战——黑马点评之附近商铺

1 认识GEO存储

1.1 GEO是什么


1.2 GEO怎么在Redis中存储


2 数据库店铺导入Redis

将数据库中的店铺数据按店铺类型type为关键字,分类存入Redis里
数据结构:
key(shop_type) -- sortedSet
sortedSet序列中元素组成为
value(shopId) -- score(X,Y)...若干个店铺坐标点
可以实现按照店铺类型,以距离为条件查询店铺信息。

      List<Shop> list = shopService.list();// 1. 采用stream流里的groupingBy方法 按照店铺类型划分为hashMapMap<Long, List<Shop>> map = list.stream().collect(Collectors.groupingBy(Shop::getTypeId));// 2. 将hashMap中的记录按键值对导入到Redis中for(Map.Entry<Long, List<Shop>> entry : map.entrySet()){// 2.1 提取存入键值对的关键字Long typeId = entry.getKey();String key = "shop:geo:" + typeId;// 2.2 获取同类型的店铺的集合List<Shop> value = entry.getValue();List<RedisGeoCommands.GeoLocation<String>> locations = new ArrayList<>(value.size());// 2.3 写入Redisfor(Shop shop : value){locations.add(new RedisGeoCommands.GeoLocation<>(shop.getId().toString(),new Point(shop.getX(),shop.getY())));}stringRedisTemplate.opsForGeo().add(key, locations);}

3 附近店铺业务实现

3.1 按店铺类型查找附近店铺

基于上述导入到Redis中的店铺GEO数据,实现需求为:
前端请求提供店铺类型shopType用来筛选Redis-set,还需提供当前用户请求的中心位置信息point(x,y),不要忘记分页查询传入的current以及MaxCount

  • 使用Redis的research功能作店铺位置查询
// 2.2 end表示分页的截止下标
int end = current * SystemConstants.DEFAULT_PAGE_SIZE;String geoSearchKey = SHOP_GEO_KEY + typeId;
// 3. 搜索返回的是 集合中的member点标识以及搜索距离
GeoResults<RedisGeoCommands.GeoLocation<String>> searchResult = stringRedisTemplate.opsForGeo().search(geoSearchKey,GeoReference.fromCoordinate(x, y),new Distance(5000),// 该方法的分页查询默认from都是从第一条记录开始RedisGeoCommands.GeoSearchCommandArgs.newGeoSearchArgs().includeDistance().limit(end));if(searchResult == null){return Result.ok(Collections.emptyList());}
  • 将全局查询出的结果作手动截取
    并对截取结果作提取 提取出需要的id集合以及距离
// 4. 解析出搜索结果中的id
List<GeoResult<RedisGeoCommands.GeoLocation<String>>> list = searchResult.getContent();if(list.size() <= from){return Result.ok(Collections.emptyList());
}
// 4.1 创建存放id序列的集合,待从数据库中查找
List<Long> ids = new ArrayList<>(list.size());
Map<String,Distance> distanceMap = new HashMap<>(list.size());
// 4.2 先对Redis中search出的结果作分页截取 从from=(current-1)*size开始截取
//     对search出的结果中提取出id 存入id集合中
list.stream().skip(from).forEach(result -> {String shopIdStr = result.getContent().getName();ids.add(Long.valueOf(shopIdStr));Distance distance = result.getDistance();distanceMap.put(shopIdStr,distance);
});
  • 根据id集合去数据库中查询店铺信息并将距离赋值
// 5. 根据id集合查询数据库
String idStr = StrUtil.join(",", ids);
List<Shop> shops = query().in("id", ids).last("ORDER BY FIELD(id," + idStr + ")").list();// 6. 对shops中的每个shop设置与id对应的距离变量
for(Shop shop:shops){Distance distance = distanceMap.get(shop.getId().toString());shop.setDistance(distance.getValue());
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/802858.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pycharm项目中mysqlclent替换使用PyMySQL

环境: OS:Windows11 Python:3.6.5 以为mysqlclient一直安装不上,下面使用PyMySQL替换mysqlclient 1.安装PyMySQLpip install PyMySQL2.然后在你的 Django 项目的 __init__.py 文件中添加以下代码来指定 Django 使用 PyMySQL:import pymysqlpymysql.install_as_MySQLdb() 3.在…

Zotero 安装教程

1. 软件安装 打开Zotero官网,点击左侧下载按钮。选择 Custom 选项:安装完后重启计算机,就可以启动并使用 Zotero 软件了。 2. 软件设置 打开 "编辑" 下的 "高级选项",查看数据存储位置。 如下图所示,数据默认存储在了 C:\Users\故梦\Zotero 里,将该文…

APGL4SR论文阅读笔记

APGL4SR: A Generic Framework with Adaptive and Personalized Global Collaborative Information in Sequential Recommendation论文阅读笔记 Abstract 现存的问题: ​ 现有方法通常只关注序列内建模,而忽略了通过序列间建模来利用全局协作信息,从而导致推荐效果不佳。以往…

DDD学习与感悟——向屎山冲锋

软件系统是通过软件开发来解决某一个业务领域或问题单元而产生的一个交付物。而通过软件设计可以帮助我们开发出更加健壮的软件系统。因此,软件设计是从业务领域到软件开发之间的桥梁。而DDD是软件设计中的其中一种思想,旨在提供一种大型复杂软件的设计思路和规范。通过DDD思…

大数据从业者必知必会的Hive SQL调优技巧

大数据从业者必知必会的Hive SQL调优技巧 摘要:在大数据领域中,Hive SQL被广泛应用于数据仓库的数据查询和分析。然而,由于数据量庞大和复杂的查询需求,Hive SQL查询的性能往往不尽人意。本文针对Hive SQL的性能优化进行深入研究,提出了一系列可行的调优方案,并给出了相应…

.net core开源工作流程框架elsa源码阅读之容器的理解

官方文档:https://v3.elsaworkflows.io/官方文档:https://v3.elsaworkflows.io/ 这个框架的依赖注入容器,底层是靠原生的IServiceCollection,没有使用其他的三方容器;然后在这个基础上,作者进行了封装。 主要是用了Module类和继承了IFeature接口的类完成了依赖注入容器的…

22320102 张怡晨9.24

思维导图:亿图 Xmind PDF转换器 :CAJ lightPDF(免费)www.light pdf.com pdf Candy

详解Diffusion扩散模型:理论、架构与实现

本文深入探讨了Diffusion扩散模型的概念、架构设计与算法实现,详细解析了模型的前向与逆向过程、编码器与解码器的设计、网络结构与训练过程,结合PyTorch代码示例,提供全面的技术指导。关注TechLead,复旦AI博士,分享AI领域全维度知识与研究。拥有10+年AI领域研究经验、复旦…

2024.9.24第二次课

思维导图制作:使用Xmind

中国大陆用户如何使用Jetbrains内置的AI插件AI Assistant

1 安装AI Assistant插件 AI功能依赖AI Assistant插件:2 功能 解释代码、回答有关代码片段的 问题、提交消息等等。 在需要时更快地编码 AI Assistant 可以自动补全单行、函数和整个代码块,并与您的编码样式、项目上下文和命名约定保持一致。AI Assistant 还可以根据您的自然语…