MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

MongoDB - DBRef

Syntaxe pour le dbref est

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

Mais vous avez ajouté un champ de quantité non pris en charge dans dbref. C'est le problème. emmène ça dehors

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

quel genre de look (effrayant)

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

Mais mon conseil est d'abandonner complètement le dbref et d'utiliser simplement la structure simple comme celle-ci

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

c'est beaucoup plus propre, ce qui ressemblera à

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