我有一个$text-Index和这样的元素的mongodb :
{
foo: "my super cool item"
}
{
foo: "your not so cool item"
}
Run Code Online (Sandbox Code Playgroud)
如果我搜索
mycoll.find({ $text: { $search: "super"} })
Run Code Online (Sandbox Code Playgroud)
我得到第一项(正确).
但我也想用"uper"搜索获得第一项 - 但如果我尝试:
mycoll.find({ $text: { $search: "uper"} })
Run Code Online (Sandbox Code Playgroud)
我没有得到任何结果.
我的问题:如果有一种方法可以使用$ text,那么它会找到搜索字符串的一部分?(例如像'%uper%'在mysql)
注意:我不要求只进行正则表达式搜索 - 我要求在$ text-search中进行正则表达式搜索!
假设我有一组用户,并希望在这些用户的用户名上实现自动完成功能.我查看了mongodb文档,$ regex似乎是一种方法.有没有更好的办法?更好的意思是更高效/更好的练习.
我想创建一个自动完成输入框,在用户键入时显示单词建议。
基本上,我的问题是,当我使用 $text 运算符在文档中搜索字符串时,查询将仅匹配完整的词干单词。出于同样的原因,如果文档字段包含单词 blueberry,则对术语 blue 的搜索将与该文档不匹配。但是,搜索 blueberry 或 blueberry 都会匹配。
find = {$text: { $search: 'blue' } };
Run Code Online (Sandbox Code Playgroud)
^(与文档中的 blueberry 或 bluebird 不匹配。)
我希望能够做到这一点。我想将 'blueberry' 或 'bluebird' 与 'blue' 匹配,最初我认为可以通过使用 'starts with' (^) 正则表达式来实现,但看起来 $text 和 $search 只接受字符串;不是正则表达式。
我想知道是否有一种方法可以做到这一点并且实施/维护不太复杂。到目前为止,我只看到人们试图通过创建一个新集合来实现此目的,并使用文本索引在集合中运行映射/归约的结果。
我不想使用 ElasticSearch 或 Solr,因为我认为这对于我想做的事情来说太过分了,虽然我有时认为最终我别无选择,但我仍然不敢相信没有更简单的方法来完成这。
我是 Mongo 的新手,想为 Web 前端实现文本搜索功能。我在“文本”索引的集合中添加了所有文本字段,因此搜索会在所有字段中找到匹配项。文件可能很重。
问题是当我收到整个匹配的文档而不仅仅是匹配的字段时。我只想随文档一起获取匹配的字段_id,因此我可以在 Web 预先输入中仅显示提示,当用户选择匹配项时,我可以通过_id.
有一个$project运算符,但问题是我不知道匹配项会出现在哪个文本字段中。