期待已久的特性,但目前仍然在beta阶段,所以官方建议不要在生产环境使用。也因此需要手动打开这个特性。

在命令行指定

mongod --setParameter textSearchEnabled=true ...

也可以放在配置文件中

setParameter = textSearchEnabled=true

还可以通过命令启动:

db.adminCommand( { setParameter : 1, textSearchEnabled : true } )

如果是用在Replica Set中,则每个结点都必须启用这个配置。

进行以上配置后,可以通过ensureIndex命令来为一个字段配置全文索引,如:

db.reviews.ensureIndex( { comments: "text" } )

关于创建全文索引的详细说明请参考这里。其中有意思的是全文索引除了对单一字段有效外,也可以配置为对文档中的所有文本字段有效:

db.collection.ensureIndex(
    { "$**": "text" },
    { name: "TextIndex" }
)

这条命令会建立一个名为“TextIndex”的对文档中所有文本字段都有效的全文索引。

全文索引只能使用text命令来访问,而不是在查找文档时默认使用。这是beta特性的特殊处理,官方预计将在2.6版本中使它变为常规find语法的一部分。大概会是这个样子:

collection.find({ caption: { $text: "query" }})

但是目前只能使用这样的语法:

t.runCommand( "text", { search : "Australian" } );

注意全文索引是大小写敏感的,这点和Sql Server不太一样,使用时要小心。并且默认只会返回头100条结果,这是由性能问题决定的。

全文索引也会丢掉无意义的冠词、数词,如a, an, the等,但这取决于使用的语言。语言可以在创建全文索引时指定:

db.collection.runCommand( "text", { search: <string>,
                                    filter: <document>,
                                    project: <document>,
                                    limit: <number>,
                                    language: <string> } )

这部分内容可以参考这里

posted on 2014-01-12 23:49  yaoxing  阅读(977)  评论(0编辑  收藏  举报