sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoDB - DBRef

Syntax för dbref är

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

Men du har lagt till kvantitetsfält som inte stöds i dbref. Det är problemet. ta det utanför

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

vilken typ av ser ut (läskigt)

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

Men mitt råd är, tappa dbref helt och hållet och använd bara den enkla strukturen så här

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

det här är mycket renare, vilket kommer att se ut

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



  1. Hur kan jag övervinna skalningsproblem med serverlös och MongoDB?

  2. Hur kan jag byta namn på ett fält för alla dokument i MongoDB?

  3. Problem med @Qualifier

  4. Rails, Sidekiq - Redis NOAUTH