MeteorJS - MongoDB - 为什么全文搜索只返回完全匹配



我正在使用与MongoDB关联的MeteorJS来创建全文搜索功能,我所做的是按照这里的步骤进行操作:http://meteorpedia.com/read/Fulltext_search,我的搜索功能现在有点"工作"。

以下是我的一些重要代码:

服务器/zip-index.js 文件:

Meteor.startup(function () {
    var search_index_name = 'my_search_index';
    // Remove old indexes as you can only have one text index and if you add
    // more fields to your index then you will need to recreate it.
    Zips._dropIndex(search_index_name);
    Zips._ensureIndex({
        city: 'text',
        state: 'text'
    }, {
        name: 'my_search_index'
    });
});

服务器/库/search_zips.js文件

var _searchZips = function (searchText) {
    var Future = Npm.require('fibers/future');
    var future = new Future();
    MongoInternals.defaultRemoteCollectionDriver().mongo.db.executeDbCommand({
            text: 'zips',
            search: searchText,
            project: {
                id: 1 // Only return the ids
            }
        }
        , function(error, results) {
            if (results && results.documents[0].ok === 1) {
                var x = results.documents[0].results;
                future.return(x);
            }
            else {
                future.return('');
            }
        });
    return future.wait();
};

现在的问题是:比如说,我有一份文件,上面有name = Washington, state = DC.

然后,当我提交搜索键="华盛顿"时,它返回所有带有name = Washington的文档;但是当我提交搜索键="洗涤"时,它什么也不返回!

所以我怀疑MongoDB的全文搜索要求搜索键与文档的字段值完全相同?你们能帮我改进我的搜索功能,以便它仍然使用 MongoDB 的全文搜索,但如果我提交不完整的搜索键,它能够返回文档事件?

我已经坚持了几个小时了。希望你们能帮上忙。非常感谢您的高级!

MongoDB全文搜索的工作原理是将所有字符串拆分为单个单词(根据索引语言使用一些词干分析)。这意味着您只能搜索完整的单词,而不能执行任何模糊搜索。

如果要搜索单词片段,可以使用正则表达式进行搜索。但请记住,正则表达式不能使用文本索引(但在某些情况下,当正则表达式以字符串开头(^)标记时,它们可以有限地使用普通索引)。

例如,查询db.Zips.find({ name: /^Washing/ }将查找名称以 "Washing" 开头的所有文档,并将受益于 { name: 1 } 上的索引。您还可以使用 db.Zips.find({ name: /DC/ } 在任何地方查找名称包含"DC"的所有文档,但它不会从任何索引中受益,并且需要执行完整的集合扫描。

当您需要更高级的文本搜索功能时,您应该考虑将MongoDB与Lucene等专用解决方案配对。

最新更新