使用表达式为数组中的字段创建文本索引
本文关键字:字段 创建 文本 索引 表达式 数组 | 更新日期: 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);
}