加入检索
This commit is contained in:
		@@ -169,6 +169,7 @@ func NewSchema() (graphql.Schema, error) {
 | 
			
		||||
				"description":   &graphql.ArgumentConfig{Type: graphql.String},
 | 
			
		||||
				"tags":          &graphql.ArgumentConfig{Type: graphql.String},
 | 
			
		||||
				"rank":          &graphql.ArgumentConfig{Type: graphql.String},
 | 
			
		||||
				"text":          &graphql.ArgumentConfig{Type: graphql.String}, // 查找图像中的文字
 | 
			
		||||
				"comment_num":   &graphql.ArgumentConfig{Type: graphql.Int},
 | 
			
		||||
				"praise_count":  &graphql.ArgumentConfig{Type: graphql.Int},
 | 
			
		||||
				"collect_count": &graphql.ArgumentConfig{Type: graphql.Int},
 | 
			
		||||
@@ -226,6 +227,67 @@ func NewSchema() (graphql.Schema, error) {
 | 
			
		||||
				if p.Args["content"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("content='%s'", p.Args["content"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["remark"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("remark='%s'", p.Args["remark"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["description"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("description='%s'", p.Args["description"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["tags"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("tags='%s'", p.Args["tags"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["rank"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("rank='%s'", p.Args["rank"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["comment_num"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("comment_num=%d", p.Args["comment_num"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["praise_count"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("praise_count=%d", p.Args["praise_count"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["collect_count"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("collect_count=%d", p.Args["collect_count"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["article_id"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("article_id=%d", p.Args["article_id"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["user_id"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("user_id=%d", p.Args["user_id"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["create_time"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("create_time='%s'", p.Args["create_time"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["update_time"] != nil {
 | 
			
		||||
					where = append(where, fmt.Sprintf("update_time='%s'", p.Args["update_time"]))
 | 
			
		||||
				}
 | 
			
		||||
				if p.Args["text"] != nil {
 | 
			
		||||
					// 通过字符串构建查询
 | 
			
		||||
					var buf strings.Builder
 | 
			
		||||
					query := map[string]interface{}{
 | 
			
		||||
						"query": map[string]interface{}{
 | 
			
		||||
							"match": map[string]interface{}{
 | 
			
		||||
								"content": p.Args["text"],
 | 
			
		||||
							},
 | 
			
		||||
						},
 | 
			
		||||
					}
 | 
			
		||||
					buf.WriteString(fmt.Sprintf("%v", query))
 | 
			
		||||
					// 执行查询
 | 
			
		||||
					var sd *models.SearchData
 | 
			
		||||
					sd = models.ElasticsearchSearch(buf.String())
 | 
			
		||||
					// 获取搜索结果的 ID 列表
 | 
			
		||||
					id_list := sd.GetIDList()
 | 
			
		||||
					// 合并为以逗号分隔的字符串
 | 
			
		||||
					id_list_str := strings.Trim(strings.Join(strings.Fields(fmt.Sprint(id_list)), ","), "[]")
 | 
			
		||||
					// 搜索结果为空
 | 
			
		||||
					if id_list_str == "" {
 | 
			
		||||
						return map[string]interface{}{
 | 
			
		||||
							"list":  []Image{},
 | 
			
		||||
							"next":  false,
 | 
			
		||||
							"total": 0,
 | 
			
		||||
						}, nil
 | 
			
		||||
					}
 | 
			
		||||
					where = append(where, fmt.Sprintf("id IN (%s)", id_list_str))
 | 
			
		||||
				}
 | 
			
		||||
				where_str := strings.Join(where, " AND ")
 | 
			
		||||
 | 
			
		||||
				// 执行查询
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user