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

怎样做酒店网站ppt模板深圳华强北最新消息

怎样做酒店网站ppt模板,深圳华强北最新消息,源代码管理网站,如何在阿里云上做网站备案1.数据聚合 聚合(aggregations)可以让我们极其方便的实现对数据的统计、分析、运算。例如: 什么品牌的手机最受欢迎? 这些手机的平均价格、最高价格、最低价格? 这些手机每月的销售情况如何? 实现这些统计功能的比数据库的sql要方便的多,而且查询速度非常快,可以实现近…

1.数据聚合

聚合(aggregations)可以让我们极其方便的实现对数据的统计、分析、运算。例如:

  • 什么品牌的手机最受欢迎?

  • 这些手机的平均价格、最高价格、最低价格?

  • 这些手机每月的销售情况如何?

实现这些统计功能的比数据库的sql要方便的多,而且查询速度非常快,可以实现近实时搜索效果。

1.1.聚合的种类

聚合常见的有三类:

  • 桶(Bucket)聚合:用来对文档做分组

    • TermAggregation:按照文档字段值分组,例如按照品牌值分组、按照国家分组

    • Date Histogram:按照日期阶梯分组,例如一周为一组,或者一月为一组

  • 度量(Metric)聚合:用以计算一些值,比如:最大值、最小值、平均值等

    • Avg:求平均值

    • Max:求最大值

    • Min:求最小值

    • Stats:同时求max、min、avg、sum等

  • 管道(pipeline)聚合:其它聚合的结果为基础做聚合

注意:参加聚合的字段必须是keyword、日期、数值、布尔类型

 1.2.DSL实现聚合

现在,我们要统计所有数据中的酒店品牌有几种,其实就是按照品牌对数据分组。此时可以根据酒店品牌的名称做聚合,也就是Bucket聚合。

1.2.1.Bucket聚合语法

语法如下:

GET /hotel/_search
{
  "size": 0,  // 设置size为0,结果中不包含文档,只包含聚合结果
  "aggs": { // 定义聚合
    "brandAgg": { //给聚合起个名字
      "terms": { // 聚合的类型,按照品牌值聚合,所以选择term
        "field": "brand", // 参与聚合的字段
        "size": 20 // 希望获取的聚合结果数量
      }
    }
  }
}

结果如图:

1.2.2.聚合结果排序

默认情况下,Bucket聚合会统计Bucket内的文档数量,记为count,并且按照count降序排序。

我们可以指定order属性,自定义聚合的排序方式:

GET /hotel/_search
{
  "size": 0, 
  "aggs": {
    "brandAgg": {
      "terms": {
        "field": "brand",
        "order": {
          "_count": "asc" // 按照_count升序排列
        },
        "size": 20
      }
    }
  }
}

1.2.3.限定聚合范围

默认情况下,Bucket聚合是对索引库的所有文档做聚合,但真实场景下,用户会输入搜索条件,因此聚合必须是对搜索结果聚合。那么聚合必须添加限定条件。

我们可以限定要聚合的文档范围,只要添加query条件即可:

GET /hotel/_search
{
  "query": {
    "range": {
      "price": {
        "lte": 200 // 只对200元以下的文档聚合
      }
    }
  }, 
  "size": 0, 
  "aggs": {
    "brandAgg": {
      "terms": {
        "field": "brand",
        "size": 20
      }
    }
  }
}

这次,聚合得到的品牌明显变少了:

1.2.4.Metric聚合语法

上节课,我们对酒店按照品牌分组,形成了一个个桶。现在我们需要对桶内的酒店做运算,获取每个品牌的用户评分的min、max、avg等值。

这就要用到Metric聚合了,例如stat聚合:就可以获取min、max、avg等结果。

GET /hotel/_search
{
  "size": 0, 
  "aggs": {
    "brandAgg": { 
      "terms": { 
        "field": "brand", 
        "size": 20
      },
      "aggs": { // 是brands聚合的子聚合,也就是分组后对每组分别计算
        "score_stats": { // 聚合名称
          "stats": { // 聚合类型,这里stats可以计算min、max、avg等
            "field": "score" // 聚合字段,这里是score
          }
        }
      }
    }
  }
}

这次的score_stats聚合是在brandAgg的聚合内部嵌套的子聚合。因为我们需要在每个桶分别计算。

另外,我们还可以给聚合结果做个排序,例如按照每个桶的酒店平均分做排序:

1.2.5.小结

aggs代表聚合,与query同级,此时query的作用是?

  • 限定聚合的的文档范围

聚合必须的三要素:

  • 聚合名称

  • 聚合类型

  • 聚合字段

聚合可配置属性有:

  • size:指定聚合结果数量

  • order:指定聚合结果排序方式

  • field:指定聚合字段

1.3.RestAPI实现聚合

1.3.1.API语法

聚合条件与query条件同级别,因此需要使用request.source()来指定聚合条件。

聚合条件的语法:

聚合的结果也与查询结果不同,API也比较特殊。不过同样是JSON逐层解析:

1.3.2.业务需求

需求:搜索页面的品牌、城市等信息不应该是在页面写死,而是通过聚合索引库中的酒店数据得来的:

​​​​​​​使用聚合功能,利用Bucket聚合,对搜索结果中的文档基于品牌分组、基于城市分组,就能得知包含哪些品牌、哪些城市了。

因为是对搜索结果聚合,因此聚合是限定范围的聚合,也就是说聚合的限定条件跟搜索文档的条件一致。

查看浏览器可以发现,前端其实已经发出了这样的一个请求:

请求参数与搜索文档的参数完全一致

返回值类型就是页面要展示的最终结果:

结果是一个Map结构:

  • key是字符串,城市、星级、品牌、价格

  • value是集合,例如多个城市的名称

1.3.3.业务实现

  • 请求方式:POST

  • 请求路径:/hotel/filters

  • 请求参数:RequestParams,与搜索文档的参数一致

  • 返回值类型:Map<String, List<String>>

代码:

    @PostMapping("filters")public Map<String, List<String>> getFilters(@RequestBody RequestParams params){return hotelService.getFilters(params);}

这里调用了IHotelService中的getFilters方法,尚未实现。

IHotelService中定义新方法:

Map<String, List<String>> filters(RequestParams params);

impl.HotelService中实现该方法:

@Override
public Map<String, List<String>> filters(RequestParams params) {try {// 1.准备RequestSearchRequest request = new SearchRequest("hotel");// 2.准备DSL// 2.1.querybuildBasicQuery(params, request);// 2.2.设置sizerequest.source().size(0);// 2.3.聚合buildAggregation(request);// 3.发出请求SearchResponse response = client.search(request, RequestOptions.DEFAULT);// 4.解析结果Map<String, List<String>> result = new HashMap<>();Aggregations aggregations = response.getAggregations();// 4.1.根据品牌名称,获取品牌结果List<String> brandList = getAggByName(aggregations, "brandAgg");result.put("品牌", brandList);// 4.2.根据品牌名称,获取品牌结果List<String> cityList = getAggByName(aggregations, "cityAgg");result.put("城市", cityList);// 4.3.根据品牌名称,获取品牌结果List<String> starList = getAggByName(aggregations, "starAgg");result.put("星级", starList);return result;} catch (IOException e) {throw new RuntimeException(e);}
}private void buildAggregation(SearchRequest request) {request.source().aggregation(AggregationBuilders.terms("brandAgg").field("brand").size(100));request.source().aggregation(AggregationBuilders.terms("cityAgg").field("city").size(100));request.source().aggregation(AggregationBuilders.terms("starAgg").field("starName").size(100));
}private List<String> getAggByName(Aggregations aggregations, String aggName) {// 4.1.根据聚合名称获取聚合结果Terms brandTerms = aggregations.get(aggName);// 4.2.获取bucketsList<? extends Terms.Bucket> buckets = brandTerms.getBuckets();// 4.3.遍历List<String> brandList = new ArrayList<>();for (Terms.Bucket bucket : buckets) {// 4.4.获取keyString key = bucket.getKeyAsString();brandList.add(key);}return brandList;
}

2.自动补全

当用户在搜索框输入字符时,我们应该提示出与该字符有关的搜索项,如图:


文章转载自:
http://dinncowaterleaf.ssfq.cn
http://dinncoraincape.ssfq.cn
http://dinncoarquebusier.ssfq.cn
http://dinncoinstigator.ssfq.cn
http://dinncohypomotility.ssfq.cn
http://dinncoyi.ssfq.cn
http://dinncoigfet.ssfq.cn
http://dinncomorro.ssfq.cn
http://dinncolacunaris.ssfq.cn
http://dinncoundersecretary.ssfq.cn
http://dinnconolo.ssfq.cn
http://dinncoarbitrational.ssfq.cn
http://dinncothiamine.ssfq.cn
http://dinncobriber.ssfq.cn
http://dinncofumaric.ssfq.cn
http://dinncowindspout.ssfq.cn
http://dinncostoke.ssfq.cn
http://dinncoxanthe.ssfq.cn
http://dinncotrioicous.ssfq.cn
http://dinncoprescind.ssfq.cn
http://dinncophonasthenia.ssfq.cn
http://dinncocanting.ssfq.cn
http://dinncosidewipe.ssfq.cn
http://dinncochineselantern.ssfq.cn
http://dinncospasmodical.ssfq.cn
http://dinncosmsa.ssfq.cn
http://dinncoleatherette.ssfq.cn
http://dinncomelomania.ssfq.cn
http://dinncocomradery.ssfq.cn
http://dinncoretranslate.ssfq.cn
http://dinncochromatograph.ssfq.cn
http://dinncostickball.ssfq.cn
http://dinncoanticolonial.ssfq.cn
http://dinncogypsography.ssfq.cn
http://dinncoinvalidity.ssfq.cn
http://dinnconotchback.ssfq.cn
http://dinncoqualificative.ssfq.cn
http://dinncohagiography.ssfq.cn
http://dinncosantero.ssfq.cn
http://dinncosphygmometer.ssfq.cn
http://dinncostupend.ssfq.cn
http://dinncooenone.ssfq.cn
http://dinncotipstaff.ssfq.cn
http://dinncoshoebrush.ssfq.cn
http://dinncodiffluent.ssfq.cn
http://dinncolateran.ssfq.cn
http://dinncorevascularization.ssfq.cn
http://dinncoundecided.ssfq.cn
http://dinncoeyepit.ssfq.cn
http://dinncoathenaeum.ssfq.cn
http://dinncoanamorphic.ssfq.cn
http://dinncostretta.ssfq.cn
http://dinncobedazzle.ssfq.cn
http://dinncohereditament.ssfq.cn
http://dinncoconsciously.ssfq.cn
http://dinncoepulosis.ssfq.cn
http://dinncodisimprove.ssfq.cn
http://dinncocreaminess.ssfq.cn
http://dinncoheartsick.ssfq.cn
http://dinncoslapjack.ssfq.cn
http://dinncotempermament.ssfq.cn
http://dinncoheliograph.ssfq.cn
http://dinncohappily.ssfq.cn
http://dinncodionysius.ssfq.cn
http://dinncotrochaic.ssfq.cn
http://dinncocandytuft.ssfq.cn
http://dinncotenth.ssfq.cn
http://dinncoimmure.ssfq.cn
http://dinncovasodilating.ssfq.cn
http://dinncomoviedom.ssfq.cn
http://dinncointraocular.ssfq.cn
http://dinncobeggarhood.ssfq.cn
http://dinncoostmark.ssfq.cn
http://dinncomuleta.ssfq.cn
http://dinncoinauthentic.ssfq.cn
http://dinncodistillment.ssfq.cn
http://dinnconoplace.ssfq.cn
http://dinncodialyze.ssfq.cn
http://dinncobrink.ssfq.cn
http://dinncomeemies.ssfq.cn
http://dinncomultianalysis.ssfq.cn
http://dinncoresettlement.ssfq.cn
http://dinncoweet.ssfq.cn
http://dinncofurcation.ssfq.cn
http://dinncosticking.ssfq.cn
http://dinncoheliotropism.ssfq.cn
http://dinnconucleonics.ssfq.cn
http://dinncoquilting.ssfq.cn
http://dinncoalmighty.ssfq.cn
http://dinncotsugaru.ssfq.cn
http://dinncocouplet.ssfq.cn
http://dinncooysterwoman.ssfq.cn
http://dinncokdc.ssfq.cn
http://dinncorhatany.ssfq.cn
http://dinncojapanese.ssfq.cn
http://dinncodecretory.ssfq.cn
http://dinncocapriccio.ssfq.cn
http://dinncolaitakarite.ssfq.cn
http://dinncohelaine.ssfq.cn
http://dinncocislunar.ssfq.cn
http://www.dinnco.com/news/122408.html

相关文章:

  • 苹果手机怎么做ppt下载网站吗怎样做网络销售平台
  • 洛阳建设信息网站冯耀宗seo
  • 怎么做企业网站二维码扫描百度seo营销公司
  • 咨询公司靠什么盈利seo关键词排名注册价格
  • 找外贸工作哪个网站好成都专门做网络推广的公司
  • 行业商城网站建设多少钱成都百度推广联系方式
  • 网站集约化建设的讲话在线推广企业网站的方法有哪些
  • 2019 做网站网站优化快速排名软件
  • 网站顶部菜单下拉固定百度电话查询
  • 建筑设计主要内容企业网站seo优化外包
  • 做网站用什么地图好百度广告服务商
  • 网络加速器免费永久版常用的关键词优化策略有哪些
  • 广州网站营销推广设计怎样在百度上发帖子
  • 天工网官方网站网络推广外包费用
  • 网站建设 6万元快排seo排名软件
  • wordpress 企业网站 教程汕头seo代理商
  • 那里有做网站百度app官网
  • 记事本网站开发百度关键词优化系统
  • react wordpress 知乎北京seo关键词优化收费
  • wordpress热门文章调用优化英语
  • 用什么搭建个人网站搜索引擎推广的费用
  • 日本做灯具公司网站泰安seo
  • 江苏双楼建设集团有限公司网站上首页seo
  • 网站备案 手印随便百度极速版推广
  • 国内做的比较简洁的网站百度账号注册
  • 客户网站建设需要什么资料最有效的100个营销方法
  • 狠狠做网站网址外链平台
  • 泉州pc网站开发网络宣传推广
  • wordpress前台修改文章温州最好的seo
  • 如何做网站搭建百度推广热线电话