sql >> Database teknologi >  >> NoSQL >> MongoDB

Konverter JSON-forespørgselsbetingelser til MongoDB/Mongoose-operationer

Du skal bygge MongoDB's $expr som ligner den forespørgsel, du får fra Angular query Builder-modulet . Da regelsættene kan indlejres, skal du køre din kortlægningsfunktion rekursivt. Nedenstående kode dækker sandsynligvis ikke alle mulige tilfælde, men bør give dig en god introduktion til at komme i gang med en sådan kortlægning.

let q = {
  "condition": "and",
  "rules": [
    {
      "field": "Brief_D_Reactiedatum",
      "operator": "!=",
      "value": "Eventtoets_Fn"
    },
    {
      "condition": "or",
      "rules": [
        {
          "field": "Alleen_AO",
          "operator": "=",
          "value": "Parkeerreden"
        }
      ]
    }
  ]
};

const conditions = { "and": "$and", "or": "$or" };
const operators = { "=": "$eq", "!=": "$ne", "<": "$lt", "<=": "$lte", ">": "$gt", ">=": "$gte" };

const mapRule = rule => ({
    [operators[rule.operator]]: [ "$"+rule.field, rule.value ]
});

const mapRuleSet = ruleSet => {
    return {
        [conditions[ruleSet.condition]]: ruleSet.rules.map(
            rule => rule.operator ? mapRule(rule) : mapRuleSet(rule)
        )
    }
};

let mongoDbQuery = { $expr: mapRuleSet(q) };
console.log(mongoDbQuery);

Resultatudtryk kan sendes enten til MongoDB's find metode

db.col.find(mongoDbQuery);

eller ind i $match pipeline fase:

db.col.aggregate([{ $match: mongoDbQuery }]);



  1. Mongoose/node.js hvordan man finder, udfylder, laver ting, 'affolker' og opdaterer

  2. Node.js fejl Fejl:Kan ikke finde modulet 'mongoose'

  3. DevOps Open-Source Database Audit Manual - Alt hvad du bør vide

  4. begrænse og sortere hver gruppe efter i mongoDB ved hjælp af aggregering