我在数据库中有一些称为“ events”的实体。每个事件都包含一个字符串数组,称为“ tags”。
。我想进行查询以获取与将在参数中提供的标记数组匹配的所有事件。
但是,我希望将这些事件排序为:
[如果有多个事件包含相同数量的标签,我希望它们按字母顺序的“ name”属性进行排序。
示例:
在此示例中,我在参数中给出的标签数组是:[“食物”,“音乐”,“游戏”,“运动”]
此示例的结果将是一个事件数组,按以下顺序包含:事件1,事件4,事件7,事件3,事件5,事件2
要获取所有包含标签的事件,我只需使用“ $ or”运算符进行查询。如果事件包含参数中给定的至少一个标记,则这使我可以获得所有事件。
代码:
var events []model.Event
var MyQuery []map[string]interface{}
for i := 0; i < len(tags); i++ {
currentCondition := bson.M{"tags": tags[i]}
MyQuery = append(MyQuery, currentCondition)
}
err := dbEvents.C(collectionEvents).Find(bson.M{"$or": OrQuery}).All(&events)
但是我真的不知道如何像我给你看的那样对它们进行排序。
package main
import (
"fmt"
"github.com/ahmetb/go-linq"
)
type T struct {
Name string
Tags []string
}
func main() {
params := []string{"food", "music", "gaming", "sport"}
t := []T{
T{Name: "event1", Tags: []string{"food", "music", "gaming", "sport"}},
T{Name: "event2", Tags: []string{"gaming"}},
T{Name: "event3", Tags: []string{"music", "sport"}},
T{Name: "event4", Tags: []string{"food", "music", "gaming", "sport"}},
T{Name: "event5", Tags: []string{"music", "coding", "sport"}},
T{Name: "event6", Tags: []string{"coding"}},
T{Name: "event7", Tags: []string{"food", "gaming", "sport"}},
}
var result []T
linq.From(t).SortT(func(t1 T, t2 T) bool {
var rs1 []string
linq.From(t1.Tags).IntersectByT(linq.From(params), func(str string) string {
return str
}).ToSlice(&rs1)
var rs2 []string
linq.From(t2.Tags).IntersectByT(linq.From(params), func(str string) string {
return str
}).ToSlice(&rs2)
return len(rs1) > len(rs2)
}).ToSlice(&result)
fmt.Printf("%+v", result)
}
[{{Name:event1标签:[食品音乐游戏运动]}} {Name:event4标签:[食品音乐游戏运动]} {Name:event7标签:[food游戏运动]} {Name:event3标签:[音乐运动]} {名称:event5标签:[音乐编码运动]} {名称:event2标签:[游戏]} {名称:event6标签:[编码]}]
上面的程序根据您的要求对数组进行排序,希望这会对您有所帮助。