Uploaded image for project: 'Core Server'
  1. Core Server
  2. SERVER-16900

regex query fails on 2.4.5 when field's value is above a certain size

    • Type: Icon: Bug Bug
    • Resolution: Duplicate
    • Priority: Icon: Major - P3 Major - P3
    • None
    • Affects Version/s: 2.4.5
    • Component/s: Querying
    • None
    • ALL
    • Hide

      1. Create a document with a field whose value is > 1011 characters on (at least) mongo 2.4.5.
      2. Search using a regex that matches a part of the field.
      3. Search using the same regex in a $or[] clause with any other regex.
      4. The first search fails, the second succeeds.

      Show
      1. Create a document with a field whose value is > 1011 characters on (at least) mongo 2.4.5. 2. Search using a regex that matches a part of the field. 3. Search using the same regex in a $or[] clause with any other regex. 4. The first search fails, the second succeeds.

      Querying with a simple regex will not return documents that match if the field size is beyond 1011 characters.

      However, searching using the same regex in a $or clause with another regex (which can be an empty search on its own) will return the correct documents.

      For example, using the document below where the big_blob value is 1012 characters long:

      [Fri Jan 16 17:15:27 ec2-user@:~ ] $ mongo --version
      MongoDB shell version: 2.4.5
      [Fri Jan 16 17:15:34 ec2-user@:~ ] $ mongod --version
      db version v2.4.5
      Fri Jan 16 17:15:37.896 git version: a2ddc68ba7c9cee17bfe69ed840383ec3506602b
      [Fri Jan 16 17:15:37 ec2-user@:~ ] $ mongo CR
      MongoDB shell version: 2.4.5
      connecting to: CR
      Reporting:PRIMARY> a= {
      ... "_id": 1,
      ... "big_blob":
      ... "Blergh1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
      ...
      ... }
      {
      	"_id" : 1,
      	"big_blob" : "Blergh1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
      }
      Reporting:PRIMARY> db.patients.save(a)
      Reporting:PRIMARY> db.patients.find({big_blob:/Blergh/})
      Reporting:PRIMARY> db.patients.find({$or:[{big_blob:/Blergh/},{fakekey:'fake'}]})
      { "_id" : 1, "big_blob" : "Blergh1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" }
      Reporting:PRIMARY>
      

      The first query fails, but the second works, even though they both should return the same document.

      compared to this example where the value is 1 character shorter, and both queries return the correct document:

      Reporting:PRIMARY> a= {
      ... "_id": 1,
      ... "big_blob":
      ... "Blergh111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
      ...
      ... }
      {
      	"_id" : 1,
      	"big_blob" : "Blergh111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
      }
      Reporting:PRIMARY> db.patients.save(a)
      Reporting:PRIMARY> db.patients.find({big_blob:/Blergh/})
      { "_id" : 1, "big_blob" : "Blergh111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" }
      Reporting:PRIMARY> db.patients.find({$or:[{big_blob:/Blergh/},{fakekey:'fake'}]})
      { "_id" : 1, "big_blob" : "Blergh111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111" }
      Reporting:PRIMARY>
      

      I've confirmed this bug does not exist in 2.6.7:

            Assignee:
            ramon.fernandez@mongodb.com Ramon Fernandez Marina
            Reporter:
            tfoss ted foss
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

              Created:
              Updated:
              Resolved: