sql >> Database >  >> NoSQL >> MongoDB

MongoDB - DBref

Syntaxis voor de dbref is

  { $ref : <collname>, $id : <idvalue>[, $db : <dbname>] }

Maar u hebt een niet-ondersteunde hoeveelheidsveld toegevoegd in dbref. Dat is het probleem. neem dat mee naar buiten

db.basket.save ({"_id" : "1", "items" : [
    {"quantity" : 5 , item : {"$ref" : "fruit", "$id" : "1"}},
    {"quantity" : 10, item : {"$ref" : "fruit", "$id" : "3"}}
]})

wat voor soort uiterlijk (eng)

{
    "_id" : "1",
    "items" : [
        {
            "quantity" : 5,
            "item" : {
                "$ref" : "fruit",
                "$id" : "1"
            }
        },
        {
            "quantity" : 10,
            "item" : {
                "$ref" : "fruit",
                "$id" : "3"
            }
        }
    ]
}

Maar mijn advies is, gooi de dbref helemaal weg en gebruik gewoon de eenvoudige structuur zoals deze

db.basket.save ({"_id" : "1",items:[
                        {item_id:"1",quantity:50},
                        {item_id:"3",quantity:10}
                ]})

dit is veel schoner, wat eruit zal zien als

{
    "_id" : "1",
    "items" : [
        {
            "item_id" : "1",
            "quantity" : 50
        },
        {
            "item_id" : "3",
            "quantity" : 10
        }
    ]
}



  1. mongoïde hash-veldwaarden instellen

  2. Meest populaire NoSQL-databases die worden ondersteund door ClusterControl

  3. Node.js Mongoose .update met ArrayFilters

  4. Flask-Mail en Redis Queue bibliotheekintegratie geven fout