使用表达式为数组中的字段创建文本索引

本文关键字:字段 创建 文本 索引 表达式 数组 | 更新日期: 2023-09-27 18:32:43

我想为数组中的多个字段和元素字段创建一个文本索引。目前,我将数组元素的路径定义为字符串,这有效。有没有办法像我对这样的简单字段一样使用表达式:

var textIndex = Builders<Project>.IndexKeys
    .Text(p => p.Name)
    .Text(p => p.Description)
    // This and any other expression I tried does not work
    //.Text(p => p.System.Elements.SelectMany(e => e.Name))
    // But this works fine:
    .Text("system.elements.name");
await collection.Indexes.CreateOneAsync(textIndex);

我正在使用mongodb 3.2和MongoDB.Driver 2.2.2

使用表达式为数组中的字段创建文本索引

我自己来这里寻找解决方案,你的想法似乎有效。我仍然只是对我的代码进行原型设计,所以它可能会更好,但对我有用的是:

private static IMongoDatabase db = dataConnector.ConnectDatabase();
private void CreateIndex(string collection)
{
    var CompoundTextIndex = new CreateIndexModel<MyDataModel>
        (Builders<MyDataModel>.IndexKeys
        .Text(x=> x.name)
        .Text(x => x.parentCompany));
    db.GetCollection<MyDataModel>
        (collection).Indexes.CreateOne(CompoundTextIndex);
}