在MongoDB模式上创建一个引用另一个模式的文本索引

时间:2015-06-12 14:08:40

标签: javascript node.js mongodb indexing mongoose

我正在尝试使用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方法为这些模式提取数据。

1 个答案:

答案 0 :(得分:3)

我认为,您正在寻找的是能够连接数据表并对该数据的总和执行查询。这是你需要关系数据库的东西,MongoDB不是。

因此,我建议您更改自己的搜索方式,例如:在作者和标题中搜索您的关键字,而不是尝试同时搜索整个数据集。