package elastic import ( "context" "encoding/json" "errors" "fmt" "github.com/olivere/elastic/v7" "hongze/hongze_yb/global" "hongze/hongze_yb/utils" ) // 首页搜索 func SearchReport(keyWord string, classifyIdList []int, pageIndex, pageSize int) (searchResp *elastic.SearchResult, total int64, err error) { indexName := global.CONFIG.EsClient.Prefix + utils.ES_INDEX_RDDP_REPORT var must []map[string]interface{} shouldSub := []map[string]interface{}{ /*map[string]interface{}{ "match": map[string]interface{}{ "Title": map[string]interface{}{ "query": keyWord, //"minimum_should_match": "60%", "boost": 3, }, }, }, map[string]interface{}{ "match": map[string]interface{}{ "Categories": map[string]interface{}{ "query": keyWord, //"minimum_should_match": "60%", "boost": 2, }, }, }, map[string]interface{}{ "match": map[string]interface{}{ "BodyContent": map[string]interface{}{ "query": keyWord, //"minimum_should_match": "60%", "boost": 1, }, }, },*/ map[string]interface{}{ "match_phrase": map[string]interface{}{ "Title": map[string]interface{}{ "query": keyWord, //"slop": "50", "boost": 5, }, }, }, map[string]interface{}{ "match_phrase": map[string]interface{}{ "Categories": map[string]interface{}{ "query": keyWord, "boost": 4, }, }, }, map[string]interface{}{ "match_phrase": map[string]interface{}{ "BodyContent": map[string]interface{}{ "query": keyWord, "boost": 3, }, }, }, } mustMap := map[string]interface{}{ "bool": map[string]interface{}{ "should": shouldSub, }, } must = append(must, mustMap) filterMust := []map[string]interface{}{ map[string]interface{}{ "term": map[string]interface{}{ "PublishState": 2, //必须是已发布的报告 }, }, map[string]interface{}{ "terms": map[string]interface{}{ "ClassifyId": classifyIdList, //分类必须是正常显示状态 }, }, } filterMustNot := []map[string]interface{}{ map[string]interface{}{ "term": map[string]interface{}{ "BodyContent.keyword": map[string]interface{}{ "value": "", //过滤没有内容的报告(晨报和周报)bodyContent 不能为空 }, }, }, } //某章节的报告,若是继承上一期的报告内容且未作修改,搜索匹配项仅展示最新一期该章节的报告。 需求池p2_838 filteCollapse := map[string]interface{}{ "field": "BodyMd5", } filterMap := map[string]interface{}{ "bool": map[string]interface{}{ "must": filterMust, "must_not": filterMustNot, }, } source := map[string]interface{}{ "query": map[string]interface{}{ "bool": map[string]interface{}{ "must": must, "filter": filterMap, }, }, } source["from"] = (pageIndex - 1) * pageSize source["size"] = pageSize source["collapse"] = filteCollapse source["highlight"] = map[string]interface{}{ "fields": map[string]interface{}{ "Title": map[string]interface{}{}, "Categories": map[string]interface{}{}, "BodyContent": map[string]interface{}{ // "pre_tags" : "{{highlight}}", // "post_tags": "{{/highlight}}", }, }, "pre_tags": "", "post_tags": "", } source["sort"] = []map[string]interface{}{ map[string]interface{}{ "PublishTime.keyword": map[string]interface{}{ "order": "desc", }, }, map[string]interface{}{ "_score": map[string]interface{}{ "order": "desc", }, }, } jsonstr, err := json.Marshal(source) fmt.Printf("%s", jsonstr) request := global.EsClient.Search(indexName).Source(source) // sets the JSON request searchResp, err = request.Do(context.Background()) if err != nil { fmt.Print("结果err:") fmt.Println(err.Error()) return } fmt.Print("结果正常:") fmt.Println(searchResp.Status) if searchResp.Status != 0 { err = errors.New("查询失败") } total = searchResp.TotalHits() return } // ReportListSearch 报告列表页的搜索 func ReportListSearch(keyWord string, classifyIdFirst int, classifyIdSeconds []int, pageIndex, pageSize int) (searchResp *elastic.SearchResult, total int64, err error) { indexName := global.CONFIG.EsClient.Prefix + utils.ES_INDEX_RDDP_REPORT var must []map[string]interface{} shouldSub := []map[string]interface{}{ map[string]interface{}{ "match": map[string]interface{}{ "Title": map[string]interface{}{ "query": keyWord, "boost": 3, }, }, }, map[string]interface{}{ "match": map[string]interface{}{ "StageStr": map[string]interface{}{ "query": keyWord, "boost": 2, }, }, }, map[string]interface{}{ "match": map[string]interface{}{ "Abstract": map[string]interface{}{ "query": keyWord, "boost": 2, }, }, }, map[string]interface{}{ "match": map[string]interface{}{ "ClassifyNameSecond": map[string]interface{}{ "query": keyWord, "boost": 2, }, }, }, map[string]interface{}{ "match_phrase": map[string]interface{}{ "Title": map[string]interface{}{ "query": keyWord, //"slop": "50", "boost": 5, }, }, }, map[string]interface{}{ "match_phrase": map[string]interface{}{ "Abstract": map[string]interface{}{ "query": keyWord, //"slop": "50", "boost": 5, }, }, }, } mustMap := map[string]interface{}{ "bool": map[string]interface{}{ "should": shouldSub, }, } must = append(must, mustMap) filter := []map[string]interface{}{ map[string]interface{}{ "term": map[string]interface{}{ "PublishState": 2, }, }, map[string]interface{}{ "term": map[string]interface{}{ "ReportChapterId": 0, //排除章节内容 }, }, map[string]interface{}{ "term": map[string]interface{}{ "ClassifyIdFirst": classifyIdFirst, }, }, map[string]interface{}{ "terms": map[string]interface{}{ "ClassifyIdSecond": classifyIdSeconds, }, }, } source := map[string]interface{}{ "query": map[string]interface{}{ "bool": map[string]interface{}{ "must": must, "filter": filter, }, }, } source["from"] = (pageIndex - 1) * pageSize source["size"] = pageSize source["highlight"] = map[string]interface{}{ "fields": map[string]interface{}{ "Title": map[string]interface{}{}, "Abstract": map[string]interface{}{}, "StageStr": map[string]interface{}{}, "ClassifyNameSecond": map[string]interface{}{}, }, "pre_tags": "", "post_tags": "", } source["sort"] = []map[string]interface{}{ map[string]interface{}{ "PublishTime.keyword": map[string]interface{}{ "order": "desc", }, }, map[string]interface{}{ "_score": map[string]interface{}{ "order": "desc", }, }, } jsonstr, err := json.Marshal(source) fmt.Printf("%s", jsonstr) request := global.EsClient.Search(indexName).Source(source) // sets the JSON request searchResp, err = request.Do(context.Background()) if err != nil { fmt.Print("结果err:") fmt.Println(err.Error()) return } fmt.Print("结果正常:") fmt.Println(searchResp.Status) if searchResp.Status != 0 { err = errors.New("查询失败") } total = searchResp.TotalHits() return }