sql >> Databasteknik >  >> NoSQL >> MongoDB

Det finns ett sätt att upprätthålla referensintegritet i MongoDB

När det gäller referensintegritet på borttagningar, förutsatt att alla raderingsförfrågningar betjänas av din applikation, kan det hanteras genom att kontrollera att ID inte finns i relaterade samlingar innan du raderar poster. Jag gör det på följande sätt

CRUD Operations (Vi är bara bekymrade över Ta bort här - notera hur jag skickar en rad objekt som är samlingen och fältet som måste matchas mot ID för dokument (post) som vi tar bort

const express = require('express')
const router = express.Router()
const iflexCRUD = require('../../lib/iflexCRUD')

const { UnitType } = require('../../models/Unittype')
const { Unit } = require('../../models/Unit')

iflexCRUD.create(router, '/', UnitType)
iflexCRUD.read(router, '/', UnitType, { sort: 'name' })
iflexCRUD.update(router, '/:id', UnitType)
iflexCRUD.deleteByID(router, '/:id', UnitType, [
  {
    model: Unit,
    field: 'unittype'
  }
])
iflexCRUD.delete(router, '/unittype/:unittype', UnitType)

module.exports = router

CRUD Delete Handler Detta är en generisk raderingsbegäranshanterare som jag använder för CRUD-operationer. Jag skickar en rad samlings-/fältvärden och kontrollerar om det finns en enda post som matchar ID:t för dokumentet som tas bort.

// CRUD-DELETE
iflexCRUD.deleteByID = (router, route, Collection, refs = []) => {
  router.delete(route, async (req, res) => {
    try {
      let exception = false
      //Enforce Referential Integrity for deletes - Deny when ID is used in any of refs collections
      //Loop through any referenced files (first record) to ensure there are no other collections using this document
      for (let i = 0; i < refs.length; i++) {
        if (!exception) {
          let refObj = {}
          refObj[refs[0].field] = req.params.id
          const result = await refs[i].model.findOne(refObj, (err, rec) => {})
          exception = result !== null
        }
      }
      // Process deletion of there are no exceptions
      if (!exception) {
        const doc = await Collection.deleteOne({ _id: req.params.id })
        res.send(doc)
      } else {
        return res
          .status(401)
          .json(
            'Document is already use in related collection  - it cannot Delete!'
          )
      }
    } catch (e) {
      return res.status(401).json(e.message)
    }
  })
}


  1. Hur använder man $regex i mongodb?

  2. En översikt över fältnivåkryptering på klientsidan i MongoDB

  3. Konvertera sträng till ObjectID i MongoDB

  4. Lagra objektegenskaper i redis