sql >> Databasteknik >  >> NoSQL >> MongoDB

I MongoDB, hur man utför en fråga baserat på om ett strängfält innehåller ett annat

Du kan göra detta med $where genom att skapa en RegExp för string1 och sedan testa den mot string2 :

db.test.find({$where: 'RegExp(this.string1).test(this.string2)'})

Men om du använder MongoDB 3.4+ kan du göra detta mer effektivt genom att använda $indexOfCP aggregeringsoperatör:

db.test.aggregate([
    // Project  the index of where string1 appears in string2, along with the original doc.
    {$project: {foundIndex: {$indexOfCP: ['$string2', '$string1']}, doc: '$$ROOT'}},
    // Filter out the docs where the string wasn't found
    {$match: {foundIndex: {$ne: -1}}},
    // Promote the original doc back to the root
    {$replaceRoot: {newRoot: '$doc'}}
])

Eller mer direkt genom att också använda $redact :

db.test.aggregate([
    {$redact: {
        $cond: {
            if: { $eq: [{$indexOfCP: ['$string2', '$string1']}, -1]},
            then: '$$PRUNE',
            else: '$$KEEP'
        }
    }}
])



  1. ställ in fältet som tomt för mongoobjekt med mongoose

  2. Hur man infogar flera dokument samtidigt i MongoDB via Java

  3. Installera mongodb på mac os 10.15 för php7

  4. Nu tillgänglig:Fullständigt värd MongoDB-instanser på AWS