我正在使用与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等专用解决方案配对。