| | |
| | | package org.springblade.es.service; |
| | | |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import org.apache.logging.log4j.util.Strings; |
| | | import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequest; |
| | |
| | | import org.elasticsearch.search.SearchHit; |
| | | import org.elasticsearch.search.SearchHits; |
| | | import org.elasticsearch.search.builder.SearchSourceBuilder; |
| | | import org.springblade.common.cache.SysCache; |
| | | import org.springblade.common.constant.EsTableConstant; |
| | | import org.springblade.common.param.CommonParamSet; |
| | | import org.springblade.common.utils.SpringUtils; |
| | | import org.springblade.es.vo.EsParam; |
| | | import org.springblade.modules.article.entity.Article; |
| | | import org.springblade.modules.article.service.ArticleService; |
| | | import org.springblade.modules.doorplateAddress.entity.DoorplateAddressEntity; |
| | | import org.springblade.modules.doorplateAddress.service.IDoorplateAddressService; |
| | | import org.springblade.modules.grid.service.IGridRangeService; |
| | | import org.springblade.modules.house.entity.HouseEntity; |
| | | import org.springblade.modules.house.entity.HouseholdEntity; |
| | | import org.springblade.modules.house.service.IHouseService; |
| | |
| | | @Autowired |
| | | private IHouseholdService householdService; |
| | | |
| | | @Autowired |
| | | private IGridRangeService gridRangeService; |
| | | |
| | | @Autowired |
| | | private IDoorplateAddressService doorplateAddressService; |
| | | |
| | | @Value("${elasticsearch.sync}") |
| | | private boolean elasticsearchSync; |
| | | |
| | |
| | | * @return |
| | | */ |
| | | public boolean init(EsParam esParam) { |
| | | // 场所 |
| | | initPlace(esParam); |
| | | // 通知文章 |
| | | initArticle(esParam); |
| | | // 房屋 |
| | | initHouse(esParam); |
| | | // 住户 |
| | | initHousehold(esParam); |
| | | if (!Strings.isBlank(esParam.getTableName())) { |
| | | if (esParam.getTableName().equals("jczz_place")) { |
| | | // 场所 |
| | | initPlace(esParam); |
| | | } |
| | | if (esParam.getTableName().equals("jczz_article")) { |
| | | // 通知文章 |
| | | initArticle(esParam); |
| | | } |
| | | if (esParam.getTableName().equals("jczz_house")) { |
| | | // 房屋 |
| | | initHouse(esParam); |
| | | } |
| | | if (esParam.getTableName().equals("jczz_household")) { |
| | | // 住户 |
| | | initHousehold(esParam); |
| | | } |
| | | } |
| | | // 返回 |
| | | return true; |
| | | } |
| | |
| | | for (Article article : articleList) { |
| | | // 初始化Elasticsearch客户端 |
| | | IndexRequest indexRequest = new IndexRequest(esParam.getIndexName()); |
| | | String communityNameListString |
| | | = SysCache.getAllCommunityNameListString(article.getArticleRange(),article.getId().toString()); |
| | | Map<String, Object> map = new HashMap<>(1); |
| | | map.put("communityCode",communityNameListString); |
| | | String toString = new JSONObject(map).toString(); |
| | | // 不设置id |
| | | // indexRequest.id("1"); |
| | | indexRequest.source("tableId", article.getId().toString(), |
| | | "tableName", "jczz_article", |
| | | "title", article.getTitle(), |
| | | "communityCode", article.getArticleRange(), |
| | | "communityCode", toString, |
| | | "type", null != article.getType() ? article.getType().toString() : "", |
| | | "content", article.getContent(), |
| | | "articleType", article.getArticleType()); |
| | |
| | | "tableId", household.getId().toString(), |
| | | "tableName", "jczz_household", |
| | | "title", household.getName(), |
| | | "relationship", household.getRelationship(), |
| | | "name", household.getName(), |
| | | "phone", household.getPhoneNumber(), |
| | | "idCard", household.getIdCard(), |
| | |
| | | @Async |
| | | public void addArticle(EsParam esParam, Article article) { |
| | | if (elasticsearchSync) { |
| | | // 查询当前文章范围对应的社区名称字符串集合 |
| | | String communityNameListString = SysCache.getAllCommunityNameListString(article.getArticleRange(),article.getId().toString()); |
| | | Map<String, Object> map = new HashMap<>(1); |
| | | map.put("communityCode",communityNameListString); |
| | | String toString = new JSONObject(map).toString(); |
| | | try { |
| | | indexDocument(esParam.getIndexName(), |
| | | "tableId", article.getId().toString(), |
| | | "tableName", "jczz_article", |
| | | "title", article.getTitle(), |
| | | "communityCode", article.getArticleRange(), |
| | | "communityCode", toString, |
| | | "type", null != article.getType() ? article.getType().toString() : "", |
| | | "content", article.getContent(), |
| | | "articleType", article.getArticleType() |
| | |
| | | * @param place |
| | | */ |
| | | @Async |
| | | public void addPlace(EsParam esParam, PlaceVO place) { |
| | | public void addPlace(EsParam esParam, PlaceEntity place) { |
| | | if (elasticsearchSync) { |
| | | if (!Strings.isBlank(place.getCommunityCode())) { |
| | | place.setCommunityCode(placeService.getCommunityCode(place.getId())); |
| | | } |
| | | try { |
| | | indexDocument(esParam.getIndexName(), |
| | | "tableId", place.getId().toString(), |
| | |
| | | "phone", place.getPrincipalPhone(), |
| | | "idCard", place.getPrincipalIdCard(), |
| | | "content", place.getLocation(), |
| | | "communityCode", place.getCommunityCode() |
| | | "communityCode", placeService.getCommunityCode(place.getId()) |
| | | ); |
| | | } catch (IOException e) { |
| | | e.printStackTrace(); |
| | |
| | | * @param house |
| | | */ |
| | | @Async |
| | | public void addHouse(EsParam esParam, HouseVO house) { |
| | | public void addHouse(EsParam esParam, HouseEntity house) { |
| | | if (elasticsearchSync) { |
| | | if (!Strings.isBlank(house.getCommunityCode())) { |
| | | house.setCommunityCode(houseService.getCommunityCode(house.getId())); |
| | | } |
| | | try { |
| | | indexDocument(esParam.getIndexName(), |
| | | "tableId", house.getId().toString(), |
| | |
| | | "phone", null, |
| | | "idCard", null, |
| | | "content", null, |
| | | "communityCode", house.getCommunityCode() |
| | | "communityCode", houseService.getCommunityCode(house.getId()) |
| | | ); |
| | | } catch (IOException e) { |
| | | e.printStackTrace(); |
| | |
| | | * @param household |
| | | */ |
| | | @Async |
| | | public void addHousehold(EsParam esParam, HouseholdVO household) { |
| | | public void addHousehold(EsParam esParam, HouseholdEntity household) { |
| | | if (elasticsearchSync) { |
| | | if (!Strings.isBlank(household.getCommunityCode())) { |
| | | household.setCommunityCode(householdService.getCommunityCode(household.getId())); |
| | | } |
| | | try { |
| | | indexDocument(esParam.getIndexName(), |
| | | "tableId", household.getId().toString(), |
| | |
| | | "name", household.getName(), |
| | | "phone", household.getPhoneNumber(), |
| | | "idCard", household.getIdCard(), |
| | | "content", household.getAddress(), |
| | | "communityCode", household.getCommunityCode() |
| | | "relationship", household.getRelationship().toString(), |
| | | "content", getAddress(household), |
| | | "communityCode", householdService.getCommunityCode(household.getId()) |
| | | ); |
| | | } catch (IOException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 获取房屋地址 |
| | | * @param household |
| | | * @return |
| | | */ |
| | | public String getAddress(HouseholdEntity household) { |
| | | if (!Strings.isBlank(household.getHouseCode())){ |
| | | // 查询对应的房屋地址 |
| | | QueryWrapper<DoorplateAddressEntity> queryWrapper = new QueryWrapper<>(); |
| | | queryWrapper.eq("address_code",household.getHouseCode()); |
| | | List<DoorplateAddressEntity> list = doorplateAddressService.list(queryWrapper); |
| | | if (list.size()>0){ |
| | | return list.get(0).getAddressName(); |
| | | } |
| | | // 房屋查不到的情况 |
| | | if (!Strings.isBlank(household.getCurrentAddress())){ |
| | | return household.getCurrentAddress(); |
| | | } |
| | | }else { |
| | | return household.getCurrentAddress(); |
| | | } |
| | | return null; |
| | | } |
| | | |
| | | /** |
| | |
| | | BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery(); |
| | | // boolQueryBuilder.should(QueryBuilders.matchQuery("content", esParam.getSearchKey())); |
| | | // boolQueryBuilder.should(QueryBuilders.matchQuery("name", esParam.getSearchKey())); |
| | | boolQueryBuilder.should(QueryBuilders.matchQuery("title", esParam.getSearchKey())); |
| | | boolQueryBuilder.should(QueryBuilders.matchPhraseQuery("title", esParam.getSearchKey())); |
| | | // boolQueryBuilder.should(QueryBuilders.matchQuery("location", esParam.getSearchKey())); |
| | | // boolQueryBuilder.should(QueryBuilders.matchQuery("phone", esParam.getSearchKey())); |
| | | // boolQueryBuilder.should(QueryBuilders.matchQuery("idCard", esParam.getSearchKey())); |
| | | String communityCode = SpringUtils.getRequestParam("communityCode"); |
| | | if (!Strings.isBlank(communityCode)) { |
| | | boolQueryBuilder.must(QueryBuilders.matchQuery("communityCode", communityCode)); |
| | | } |
| | | if (!Strings.isBlank(esParam.getTableName())) { |
| | | boolQueryBuilder.must(QueryBuilders.matchQuery("tableName", esParam.getTableName())); |
| | | } |
| | | String roleName = SpringUtils.getRequestParam("roleName"); |
| | | String communityCode = SpringUtils.getRequestParam("communityCode"); |
| | | if (!Strings.isBlank(communityCode)) { |
| | | if (!Strings.isBlank(roleName) && roleName.equals("inhabitant") && !Strings.isBlank(esParam.getHouseCode())){ |
| | | // 居民根据房屋对应的小区过滤 |
| | | boolQueryBuilder.must(QueryBuilders.matchPhraseQuery("communityCode",gridRangeService.getDistrictIdByHouseCode(esParam.getHouseCode()))); |
| | | }else { |
| | | // 设置查询社区名称,编号有多个,数字类型目前无法匹配到 |
| | | boolQueryBuilder.must(QueryBuilders.matchPhraseQuery("communityCode", communityCode)); |
| | | } |
| | | } |
| | | if (!Strings.isBlank(roleName)){ |
| | | if (roleName.equals("wgy") || roleName.equals("mj")){ |
| | | // 不查公告 |
| | | boolQueryBuilder.mustNot(QueryBuilders.matchQuery("tableName", "jczz_article")); |
| | | } |
| | | if (roleName.equals("inhabitant")){ |
| | | // 只查公告 |
| | | boolQueryBuilder.must(QueryBuilders.matchQuery("tableName", "jczz_article")); |
| | | } |
| | | if (roleName.equals("wzcj")){ |
| | | // 只查场所 |
| | | boolQueryBuilder.must(QueryBuilders.matchQuery("tableName", "jczz_place")); |
| | | } |
| | | } |
| | | |
| | | boolQueryBuilder.minimumShouldMatch(1); |
| | | searchSourceBuilder.query(boolQueryBuilder); |
| | | |
| | |
| | | */ |
| | | public boolean removeBatchByIndexNames(List<String> indexNames) { |
| | | for (String indexName : indexNames) { |
| | | DeleteIndexRequest deleteIndexRequest = new DeleteIndexRequest(indexName); |
| | | try { |
| | | // 执行删除索引操作 |
| | | AcknowledgedResponse deleteResponse = client.indices().delete(deleteIndexRequest, RequestOptions.DEFAULT); |
| | | // 索引存在才删除 |
| | | if (isIndexExists(indexName)) { |
| | | DeleteIndexRequest deleteIndexRequest = new DeleteIndexRequest(indexName); |
| | | try { |
| | | // 执行删除索引操作 |
| | | AcknowledgedResponse deleteResponse = client.indices().delete(deleteIndexRequest, RequestOptions.DEFAULT); |
| | | |
| | | // 输出操作结果 |
| | | boolean acknowledged = deleteResponse.isAcknowledged(); |
| | | System.out.println("索引删除成功: " + acknowledged); |
| | | } catch (IOException e) { |
| | | e.printStackTrace(); |
| | | // 输出操作结果 |
| | | boolean acknowledged = deleteResponse.isAcknowledged(); |
| | | System.out.println("索引删除成功: " + acknowledged); |
| | | } catch (IOException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | } |
| | | } |
| | | return true; |
| | |
| | | */ |
| | | @Async |
| | | public void update(EsParam esParam, T item,List<String> columnList) { |
| | | if (elasticsearchSync) { |
| | | // 判断索引是否存在 |
| | | if (elasticsearchSync && isIndexExists(esParam.getIndexName())) { |
| | | // 创建更新请求 |
| | | UpdateByQueryRequest updateRequest = new UpdateByQueryRequest(esParam.getIndexName()); |
| | | |
| | |
| | | |
| | | Map<String, Object> data = new HashMap<String, Object>(); |
| | | data.put("tableName", esParam.getTableName()); |
| | | if (esParam.getTableName().equals("jczz_article")){ |
| | | setArticleMap((Article)item,data); |
| | | if (esParam.getTableName().equals("jczz_article")) { |
| | | setArticleMap((Article) item, data); |
| | | } |
| | | if (esParam.getTableName().equals("jczz_place")){ |
| | | setPlaceMap((PlaceEntity) item,data); |
| | | if (esParam.getTableName().equals("jczz_place")) { |
| | | setPlaceMap((PlaceEntity) item, data); |
| | | } |
| | | if (esParam.getTableName().equals("jczz_house")){ |
| | | setHouseMap((HouseEntity) item,data); |
| | | if (esParam.getTableName().equals("jczz_house")) { |
| | | setHouseMap((HouseEntity) item, data); |
| | | } |
| | | if (esParam.getTableName().equals("jczz_household")){ |
| | | setHousehouldMap((HouseholdEntity) item,data); |
| | | if (esParam.getTableName().equals("jczz_household")) { |
| | | setHouseholdMap((HouseholdEntity) item, data); |
| | | } |
| | | Map<String, Object> param = new HashMap<String, Object>(); |
| | | param.put("data", data); |
| | |
| | | * @param data |
| | | */ |
| | | private void setArticleMap(Article item, Map<String, Object> data) { |
| | | // 查询当前文章范围对应的社区名称字符串集合 |
| | | String communityNameListString = SysCache.getAllCommunityNameListString(item.getArticleRange(),item.getId().toString()); |
| | | Map<String, Object> map = new HashMap<>(1); |
| | | map.put("communityCode",communityNameListString); |
| | | String toString = new JSONObject(map).toString(); |
| | | data.put("tableId",item.getId()); |
| | | data.put("title",item.getTitle()); |
| | | data.put("type",item.getType()); |
| | | data.put("content",item.getContent()); |
| | | data.put("articleType",item.getArticleType()); |
| | | data.put("communityCode",item.getArticleRange()); |
| | | data.put("communityCode",toString); |
| | | } |
| | | /** |
| | | * 设置场所map |
| | |
| | | * @param item |
| | | * @param data |
| | | */ |
| | | private void setHousehouldMap(HouseholdEntity item, Map<String, Object> data) { |
| | | private void setHouseholdMap(HouseholdEntity item, Map<String, Object> data) { |
| | | data.put("communityCode",householdService.getCommunityCode(item.getId())); |
| | | data.put("tableId",item.getId()); |
| | | data.put("title",item.getName()); |
| | | data.put("relationship",item.getRelationship()); |
| | | data.put("name",item.getName()); |
| | | data.put("phone",item.getPhoneNumber()); |
| | | data.put("idCard",item.getIdCard()); |
| | | data.put("content",item.getCurrentAddress()); |
| | | data.put("content",getAddress(item)); |
| | | } |
| | | |
| | | /** |
| | | * 删除数据--根据条件 |
| | | */ |
| | | public boolean removeByQuery(EsParam esParam) { |
| | | if (elasticsearchSync) { |
| | | if (elasticsearchSync && isIndexExists(esParam.getIndexName())) { |
| | | DeleteByQueryRequest deleteByQueryRequest = new DeleteByQueryRequest(esParam.getIndexName()); |
| | | // 根据多个条件 生成 boolQueryBuilder |
| | | BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery(); |
| | | boolQueryBuilder |
| | | .must(QueryBuilders.matchQuery("tableId", esParam.getTableId())) |
| | | .must(QueryBuilders.matchQuery("tableName", esParam.getTableName())); |
| | | if (!Strings.isBlank(esParam.getTableId())){ |
| | | boolQueryBuilder |
| | | .must(QueryBuilders.matchQuery("tableId", esParam.getTableId())); |
| | | } |
| | | if (!Strings.isBlank(esParam.getTableName())) { |
| | | boolQueryBuilder |
| | | .must(QueryBuilders.matchQuery("tableName", esParam.getTableName())); |
| | | } |
| | | deleteByQueryRequest.setQuery(boolQueryBuilder); |
| | | try { |
| | | BulkByScrollResponse bulkResponse = |