Elasticsearch+SpringBoot开发搜房Demo(2)--增删改

2024-05-09 23:19

本文主要是介绍Elasticsearch+SpringBoot开发搜房Demo(2)--增删改,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mysql和Elasticsearch 一般同时使用。在对mysql增删改的同时,也需要在Elasticsearch同步数据操作。
首先,建立对应的java实体对象

public class HouseIndexTemplate {private Long houseId;private String title;private int price;private int area;private Date createTime;private Date lastUpdateTime;private String cityEnName;private String regionEnName;private int direction;private int distanceToSubway;private String subwayLineName;private String subwayStationName;private String street;private String district;private String description;private String layoutDesc;private String traffic;private String roundService;private int rentWay;private List<String> tags;private List<HouseSuggest> suggest;......
}

增加,修改都是先在es中查找有没有对应houseid,
没有的话是新建操作,找到一个的话修改操作,
找到多个的话是先删除后修改操作。原始的house信息都是从mysql里查到。

 private void createOrUpdateIndex(HouseIndexMessage message) {Long houseId = message.getHouseId();House house = houseRepository.findOne(houseId);if (house == null) {logger.error("Index house {} dose not exist!", houseId);this.index(houseId, message.getRetry() + 1);return;}HouseIndexTemplate indexTemplate = new HouseIndexTemplate();modelMapper.map(house, indexTemplate);HouseDetail detail = houseDetailRepository.findByHouseId(houseId);if (detail == null) {// TODO 异常情况}modelMapper.map(detail, indexTemplate);SupportAddress city = supportAddressRepository.findByEnNameAndLevel(house.getCityEnName(), SupportAddress.Level.CITY.getValue());SupportAddress region = supportAddressRepository.findByEnNameAndLevel(house.getRegionEnName(), SupportAddress.Level.REGION.getValue());String address = city.getCnName() + region.getCnName() + house.getStreet() + house.getDistrict() + detail.getDetailAddress();ServiceResult<BaiduMapLocation> location = addressService.getBaiduMapLocation(city.getCnName(), address);if (!location.isSuccess()) {this.index(message.getHouseId(), message.getRetry() + 1);return;}indexTemplate.setLocation(location.getResult());List<HouseTag> tags = tagRepository.findAllByHouseId(houseId);if (tags != null && !tags.isEmpty()) {List<String> tagStrings = new ArrayList<>();tags.forEach(houseTag -> tagStrings.add(houseTag.getName()));indexTemplate.setTags(tagStrings);}SearchRequestBuilder requestBuilder = this.esClient.prepareSearch(INDEX_NAME).setTypes(INDEX_TYPE).setQuery(QueryBuilders.termQuery(HouseIndexKey.HOUSE_ID, houseId));logger.debug(requestBuilder.toString());SearchResponse searchResponse = requestBuilder.get();boolean success;long totalHit = searchResponse.getHits().getTotalHits();if (totalHit == 0) {success = create(indexTemplate);} else if (totalHit == 1) {String esId = searchResponse.getHits().getAt(0).getId();success = update(esId, indexTemplate);} else {success = deleteAndCreate(totalHit, indexTemplate);}ServiceResult serviceResult = addressService.lbsUpload(location.getResult(), house.getStreet() + house.getDistrict(),city.getCnName() + region.getCnName() + house.getStreet() + house.getDistrict(),message.getHouseId(), house.getPrice(), house.getArea());if (!success || !serviceResult.isSuccess()) {this.index(message.getHouseId(), message.getRetry() + 1);} else {logger.debug("Index success with house " + houseId);}}private void removeIndex(HouseIndexMessage message) {Long houseId = message.getHouseId();DeleteByQueryRequestBuilder builder = DeleteByQueryAction.INSTANCE.newRequestBuilder(esClient).filter(QueryBuilders.termQuery(HouseIndexKey.HOUSE_ID, houseId)).source(INDEX_NAME);logger.debug("Delete by query for house: " + builder);BulkByScrollResponse response = builder.get();long deleted = response.getDeleted();logger.debug("Delete total " + deleted);ServiceResult serviceResult = addressService.removeLbs(houseId);if (!serviceResult.isSuccess() || deleted <= 0) {logger.warn("Did not remove data from es for response: " + response);// 重新加入消息队列this.remove(houseId, message.getRetry() + 1);}}private boolean create(HouseIndexTemplate indexTemplate) {if (!updateSuggest(indexTemplate)) {return false;}try {IndexResponse response = this.esClient.prepareIndex(INDEX_NAME, INDEX_TYPE).setSource(objectMapper.writeValueAsBytes(indexTemplate), XContentType.JSON).get();logger.debug("Create index with house: " + indexTemplate.getHouseId());if (response.status() == RestStatus.CREATED) {return true;} else {return false;}} catch (JsonProcessingException e) {logger.error("Error to index house " + indexTemplate.getHouseId(), e);return false;}}private boolean update(String esId, HouseIndexTemplate indexTemplate) {if (!updateSuggest(indexTemplate)) {return false;}try {UpdateResponse response = this.esClient.prepareUpdate(INDEX_NAME, INDEX_TYPE, esId).setDoc(objectMapper.writeValueAsBytes(indexTemplate), XContentType.JSON).get();logger.debug("Update index with house: " + indexTemplate.getHouseId());if (response.status() == RestStatus.OK) {return true;} else {return false;}} catch (JsonProcessingException e) {logger.error("Error to index house " + indexTemplate.getHouseId(), e);return false;}}private boolean deleteAndCreate(long totalHit, HouseIndexTemplate indexTemplate) {DeleteByQueryRequestBuilder builder = DeleteByQueryAction.INSTANCE.newRequestBuilder(esClient).filter(QueryBuilders.termQuery(HouseIndexKey.HOUSE_ID, indexTemplate.getHouseId())).source(INDEX_NAME);logger.debug("Delete by query for house: " + builder);BulkByScrollResponse response = builder.get();long deleted = response.getDeleted();if (deleted != totalHit) {logger.warn("Need delete {}, but {} was deleted!", totalHit, deleted);return false;} else {return create(indexTemplate);}}

这篇关于Elasticsearch+SpringBoot开发搜房Demo(2)--增删改的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/974786

相关文章

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android开发环境配置避坑指南

《Android开发环境配置避坑指南》本文主要介绍了Android开发环境配置过程中遇到的问题及解决方案,包括VPN注意事项、工具版本统一、Gerrit邮箱配置、Git拉取和提交代码、MergevsR... 目录网络环境:VPN 注意事项工具版本统一:android Studio & JDKGerrit的邮

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.