我正在尝试使用mongoose为某个Schema添加索引以进行文本搜索。如果我将文本索引添加到单个字段,它可以正常工作,也可以使用复合索引,它是可以的。例如,这里提供的答案很棒:
Full text search with weight in mongoose
但是,我正在尝试向引用其他Schema的字段添加索引。例如,我的模型如下所示:
var Book = new Schema({
"title": String,
"createdAt": Date,
"publisher": {
"type": Schema.ObjectId,
"ref": "Publisher"
},
"author": {
"type": Schema.ObjectId,
"ref": "Author"
},
"isbn": String
});
因此,当您执行如下所述的搜索查询时,以下索引不起作用:
索引:
Book.index({"title": "text", "publisher.name": "text", "author.firstName": "text"});
搜索查询:
function searchBooks(req, res) {
var query = req.query.searchQuery;
Book.find({ $text: { $search: query } })
.populate('author publisher')
.limit(25)
.exec(function(err, books) {
if (err) {
res.json(err);
} else {
res.json(books);
}
}
);
}
有没有人建议如何为"发布商"添加文本索引?和"作者"字段,我正在使用"填充" mongodb方法为这些模式提取数据。
答案 0 :(得分:3)
我认为,您正在寻找的是能够连接数据表并对该数据的总和执行查询。这是你需要关系数据库的东西,MongoDB不是。
因此,我建议您更改自己的搜索方式,例如:在作者和标题中搜索您的关键字,而不是尝试同时搜索整个数据集。