Full Text Search in MongoDB not yielding the expected result for “@@@”

前端 未结 2 1219
南方客
南方客 2021-01-21 19:47

So I have a document in a collection with on of the fields having a value \"@@@\" I indexed the collection and tried running the query:

db.getCollection(\'TestColl

相关标签:
2条回答
  • 2021-01-21 20:29

    Your query has to many curly braces, remove them:

    db.getCollection('so2').find({$text:{$search:"\"@@@\""}})
    

    If you run it, Mongo tells you you're missing a text index. Add it like this:

    db.so2.createIndex( { field2: "text" } )
    

    The value you're using is pretty small. Try using longer values.

    0 讨论(0)
  • 2021-01-21 20:36

    Text search is designed to index strings based on language heuristics. Text indexing involves two general steps: tokenizing (converting a string into individual terms of interest) followed by stemming (converting each term into a root form for indexing based on language-specific rules).

    During the tokenizing step certain characters (for example, punctuation symbols such as @) are classified as word separators (aka delimiters) rather than text input and used to separate the original string into terms. Language-specific stop words (common words such as "the", "is", or "on" in English) are also excluded from a text index.

    Since your search phrase of @@@ consists entirely of delimiters, there is no corresponding entry in the text index.

    If you want to match generic string patterns, you should use regular expressions rather than text search. For example: db.getCollection('TestCollection').find({field2:/@@@/}). However, please note the caveats on index usage for regular expressions.

    0 讨论(0)
提交回复
热议问题