当前位置: 首页 > news >正文

redis_点评(25.附件店铺—把数据库里的店铺按【类型分组】,批量导入Redis 的 GEO 地理位置结构)

店铺数据批量导入 Redis GEO 详解

这段代码的核心目标是:把数据库里的店铺数据,按类型分组后,批量写入 Redis 的 GEO 结构,为后续“附近店铺”查询做准备


一、整体流程概览


二、逐行代码拆解

1. 环境准备

@Resource private StringRedisTemplate stringRedisTemplate;

注入StringRedisTemplate,用于操作 Redis,尤其是 GEO 相关命令。


2. 主方法loadShopData()

@Test void loadShopData(){ // 1. 查询店铺信息 List<Shop> list = shopService.list();
  • 调用shopService.list()从数据库中查询所有店铺

  • 得到List<Shop>,包含所有店铺的ID、类型ID、经纬度等信息。


3. 按店铺类型分组

// 2. 把店铺分组,按照typeId分组,typeId一致的放到一个集合 Map<Long, List<Shop>> map = list.stream() .collect(Collectors.groupingBy(Shop::getTypeId));
  • 使用 Java 8 Stream 的Collectors.groupingBy,按Shop::getTypeId(店铺类型ID)分组。

  • 结果:Map<Long, List<Shop>>,Key 是typeId,Value 是该类型下的所有店铺列表。


4. 遍历分组,批量写入 Redis

// 3. 分批完成写入Redis for (Map.Entry<Long, List<Shop>> entry : map.entrySet()) { // 3.1 获取类型id Long typeId = entry.getKey(); String key = "shop:geo:" + typeId; // 3.2 获取同类型的店铺的集合 List<Shop> value = entry.getValue(); List<RedisGeoCommands.GeoLocation<String>> locations = new ArrayList<>(value.size()); // 3.3 构建GeoLocation对象 for (Shop shop : value) { locations.add(new RedisGeoCommands.GeoLocation<>( shop.getId().toString(), // member:店铺ID new Point(shop.getX(), shop.getY()) // 经纬度 )); } // 3.4 批量写入Redis GEO stringRedisTemplate.opsForGeo().add(key, locations); }
一、逐段关键解释
1.map.entrySet()
  • 所属:java.util.Map接口的方法

  • 作用:把Map转成一个「键值对集合」,方便for-each遍历

  • 业务含义:遍历按typeId分组后的店铺数据,拿到每一组的typeId和该类型下的所有店铺


2.RedisGeoCommands.GeoLocation
  • 所属:Spring Data Redis 提供的地理位置实体类

  • 用途:专门给 Redis GEO 功能封装数据,只存两个东西:

    • name:成员名称(这里存店铺 ID,后续查询时可直接拿到)

    • point:坐标点(经度 + 纬度)


3.List<RedisGeoCommands.GeoLocation<String>> locations = new ArrayList<>(shops.size());
  • 含义:创建一个List集合,名字叫locations,只能装GeoLocation类型的对象

  • 通俗理解:一个专门装地理位置的盒子,初始容量设为店铺数量,避免扩容开销


4.locations.add(new RedisGeoCommands.GeoLocation<>(...))
  • 含义:创建一个新的GeoLocation对象(单个店铺的地理位置),然后add放进上面的locations集合里

  • 通俗理解:把一个个 “地理位置” 放进 “盒子” 里,准备批量写入 Redis


5.stringRedisTemplate.opsForGeo().add(key, locations);
  • 作用:一次性把locations盒子里的所有数据,批量写入 Redis GEO 集合

  • 优势:比单条写入减少多次网络 IO,大幅提升导入效率

6.关键细节:
  • Redis Key 设计shop:geo:{typeId},不同类型的店铺存储在不同的 GEO 集合中,后续查询时按类型筛选更高效。

  • GeoLocation对象

    • member:店铺ID(后续查询结果中返回的标识)

    • Point:店铺的经纬度(x, y)

  • 批量写入优化:先构建好所有GeoLocation对象,再一次性调用add(key, locations),避免多次网络IO,大幅提升导入效率。


三、核心技术点:Redis GEO

Redis GEO 是专门用于存储和查询地理位置数据的数据结构,核心命令包括:

  • GEOADD key longitude latitude member:添加地理位置

  • GEORADIUS key longitude latitude radius:按半径查询附近的成员

这段代码中,我们把每个类型的店铺都存入了对应shop:geo:{typeId}的 GEO 集合中,后续就可以直接用GEORADIUS命令,查询指定经纬度附近的该类型店铺。


四、总结

这段代码将数据库中的所有店铺按类型分组,批量构建为GeoLocation对象,并一次性写入 Redis GEO 结构,为后续实现“附近店铺”查询功能做数据准备。

http://www.rkmt.cn/news/1511766.html

相关文章:

  • 避坑指南:在OpenFOAM的twoPhaseEulerFoam中正确选择曳力模型(以WenYu和Ergun为例)
  • 义乌财税服务口碑榜 | 正规资质・全程代办・财税护航 —— 科启财税 荣伦财税凭专业服务领跑义乌企业注册赛道 - 资讯快报
  • 2026 库尔勒黄金回收市场解析:5 大机构测评、行情与避坑要点 - 速递信息
  • 2026 年驿城区短视频全链路流量运营与本地首页排位:中小企业线上引流完整策略 - 年度推荐企业名录
  • FastReport开源报表工具:5步打造专业级数据可视化报表
  • 2026年 欧米茄官方售后服务网点实地考察报告(中国区60+门店全覆盖) - 欧米茄中国服务中心
  • 欧洲专列X吉马冠名X抖音榜首:解锁后谷咖啡“圈粉密码”! - 品牌速递
  • 从星巴克排队到服务器请求:M/M/1模型教你量化‘拥堵’,优化资源配置
  • UnicodeIt:LaTeX到Unicode转换的终极解决方案
  • SDE | 均方收敛阶
  • 2026年溧阳高端民宿消费指南 - 速递信息
  • 南京信息工程大学助学自考:资质与办学细节实测评测 - 奔跑123
  • CFR Java反编译深度解析:从字节码到现代Java语法的逆向工程艺术
  • APP盲盒源码V6MAX:资产体系升级打造运营闭环 - 壹软科技
  • 37 年深耕润滑油行业,康普顿润滑油凭硬核品控收获好口碑 - GrowthUME
  • AgentScope实战训练营:手把手教你打造基于RocketMQ的 A2A 智能体通信系统
  • 本地消费红包系统的风控设计:动态档位、活跃系数与熔断机制
  • VC6下可直接运行的MFC串口调试工具源码,带XModem文件收发功能
  • d3dxSkinManage终极指南:三分钟掌握专业MOD管理,彻底解决游戏贴图异常问题
  • 2026 年驻马店抖音同城流量运维与搜索权重优化:本地企业线上精准拓客全套方案 - 年度推荐企业名录
  • 终极本地流程图神器:5分钟掌握drawio-desktop的完整使用指南
  • 佛山回收包包门店怎么选?五大正规奢品商家测评,推荐榜单 - 名奢变现站
  • LangChain框架在高炉炼铁智能化领域的应用~系列文章03:模型调用篇 — 选对模型,高炉炼铁事半功倍
  • 2026全规模企业微信SCRM系统推荐:从初创团队到集团公司的全行业适配方案 - 资讯纵览
  • 5个AI Agent工作流,让半导体工程师准时下班(附Prompt)
  • 东莞手表回收“现场拆盖”是标准流程还是风险操作?2026实测告诉你 - 奢侈品交易观察员
  • 2026阜阳婚纱照真实测评|10家机构深度横评 避坑指南附TOP榜单 - 江湖评测
  • 新鲜春招面经:百度京东大数据原题拆解,AI + 数仓已成面试新风向
  • Claude归零层:语义锚点快照如何重构大模型推理成本
  • 别再只懂Over模式了!用Python+OpenCV实战Alpha融合的5种模式(附完整代码)