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

ASP.NET网站建设实战响应式网站建设过时吗

ASP.NET网站建设实战,响应式网站建设过时吗,基于h5的企业网站建设,明星用什么软件做视频网站一、背景 课程管理界面,查询前,需要把查询元数据给出。 学科列表、学段列表和分类列表,我们把它定义为查询元数据。 一般的业务需求是: 系统维护好多个字典,比如学科、学段等等,相当于属性库。 但是&…

一、背景

课程管理界面,查询前,需要把查询元数据给出。
学科列表、学段列表和分类列表,我们把它定义为查询元数据。

在这里插入图片描述

一般的业务需求是:
系统维护好多个字典,比如学科、学段等等,相当于属性库。

但是,这有一个不友好的地方,字典列表数据过多,比如学段字典包括了幼儿园和大学等,而实际上,课程只有初中或高中,连小学学段也没有。

这样展示的学段列表,就显得数据冗余,增加选择的干扰。

修改后的需求:
基于已有课程的属性,进行去重查询出学科列表等数据,也即上文提到的查询元数据。(已非原始字典)

比如说,我创建了一个课程,它是数学科目,初中学段,那么查询列表中的学科列表就只有数学一个值,学段列表只有初中一个值。

后期创建了一个化学科目的高中课程,此时学科列表就有数学和化学两个学科,学段包括初中和高中。

二、es索引

@Data
@Document(indexName = "#{commonConfig.courseIdx}", type = "_doc", shards = 1, refreshInterval = "-1")
public class CourseIndex implements Serializable {@Idprivate String id;/*** 课程编号*/@Field(type = FieldType.Keyword)private String courseNo;/*** 创建者ID*/@Field(type = FieldType.Long)private long creatorId;/*** 课程名称*/@Field(type = FieldType.Text)private String name;/*** 科目*/@Field(type = FieldType.Integer)private int subject;/*** 学段*/@Field(type = FieldType.Integer)private int stage;
}

三、es聚合查询


import lombok.RequiredArgsConstructor;
import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.aggregations.Aggregation;
import org.elasticsearch.search.aggregations.AggregationBuilders;
import org.elasticsearch.search.aggregations.bucket.terms.ParsedLongTerms;
import org.elasticsearch.search.aggregations.bucket.terms.Terms;
import org.elasticsearch.search.aggregations.bucket.terms.TermsAggregationBuilder;
import org.springframework.data.elasticsearch.core.ElasticsearchRestTemplate;
import org.springframework.data.elasticsearch.core.aggregation.AggregatedPage;
import org.springframework.data.elasticsearch.core.query.NativeSearchQueryBuilder;
import org.springframework.stereotype.Component;import java.util.ArrayList;
import java.util.List;@Component
@RequiredArgsConstructor
public class CourseIndexAggrService {private final ElasticsearchRestTemplate elasticsearchRestTemplate;private static final String UNIQUE_FIELD = "unique_field";public static final String SUBJECT = "subject";public static final String STAGE = "stage";public List<String> findUniqueField(String uniqueField) {NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();boolQueryBuilder.filter(QueryBuilders.termQuery("deleted", LogicDeleteEnum.OK.ordinal()));queryBuilder.withQuery(boolQueryBuilder);TermsAggregationBuilder termsAgg = AggregationBuilders.terms(UNIQUE_FIELD).field(uniqueField);queryBuilder.addAggregation(termsAgg);queryBuilder.withIndices("course_index");AggregatedPage<CourseIndex> resultPage = elasticsearchRestTemplate.queryForPage(queryBuilder.build(), CourseIndex.class);Aggregation aggregation = resultPage.getAggregation(UNIQUE_FIELD);ParsedLongTerms terms = (ParsedLongTerms) aggregation;// 获取桶final List<? extends Terms.Bucket> buckets = terms.getBuckets();// 提取唯一值List<String> uniqueUserIds = new ArrayList<>();for (Terms.Bucket bucket : buckets) {uniqueUserIds.add(bucket.getKeyAsString());}return uniqueUserIds;}
}

四、调用示例

// 科目列表
final List<Integer> subjects = courseIndexAggrService.findUniqueField(SUBJECT).stream().map(v -> Integer.parseInt(v)).collect(Collectors.toList());// 学段列表
final List<Integer> stages = courseIndexAggrService.findUniqueField(STAGE).stream().map(v -> Integer.parseInt(v)).collect(Collectors.toList());
http://www.dtcms.com/wzjs/537743.html

相关文章:

  • 建网站赚钱方法哪里有做效果图的
  • 济南网络公司建站果洛电子商务网站建设多少钱
  • 可信网站查询官网有哪些网站做的很好
  • 做全景效果图的网站网站与与云的关系
  • 国外二手表网站天元建设集团有限公司上班时间
  • 如何在百度上建网站正规品牌网站设计品牌
  • 网站制作公司电话网站开发售后服务
  • 模板网站多钱网页设计作业10个页面
  • vultr建站wordpress长春启做网站多少
  • 网站建设市场占有率如何选择网站做站方向
  • 免费建站网站一级大录像不卡在线看网页保定建网站
  • 2014苏州建设银行招聘网站网络舆情的网站
  • 江苏网站建设网站排名优化wordpress网站前台打开慢
  • 网站 什么语言开发的网站推广--html关键词代码解说
  • 专门做丝印反查的收费网站网站建设攻略
  • 介绍一学一做视频网站酒店网站建站
  • 建站合同wordpress电商ar
  • 如何建设学校网站有教做鱼骨图的网站吗
  • 深圳网站制作网站建设怎么制作网站深圳博纳什么网站空间稳定
  • 企业网站的开发背景中小企业网站制作
  • 2016个人做淘宝客网站营业执照年审登录入口
  • 很长的网站域名怎么做短wordpress国内现状
  • 阿里云用什么系统做网站好wordpress建站环境
  • 如何查网站的icp备案四川建设网官网安全员证书查询
  • 网站左侧悬浮代码专业建设规划及实施方案
  • 四川网站建设找哪家湖南微信网站公司
  • 企业做自己的网站要注意什么手工制作书签
  • wordpress设置页面透明度郑州seo外包顾问
  • 河南网站建设设计价格wordpress mysql加速
  • 婚介做网站的好处嘉峪关建设路小学网站