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

Unikke dokumenter i en MongoDB-samling

Nå, du kan bruge MongoDBs unikke sammensatte indeks

db.users.createIndex( { user: 1, comment: 1, whatever: 1 }, { unique: true } )

Et par tilfælde:

> db.users.insert({user: "A", comment: "B", whatever: "C"})
WriteResult({ "nInserted" : 1 })
> db.users.insert({user: "A", comment: "C", whatever: "B"})
WriteResult({ "nInserted" : 1 })
> db.users.insert({user: "A", comment: "B", whatever: "C"})
> WriteResult({

    "nInserted" : 0,
    "writeError" : {
            "code" : 11000,
            "errmsg" : "insertDocument :: caused by :: 11000 E11000 duplicate key error index: test.users.$user_1_comment_1_whatev
er_1  dup key: { : \"A\", : \"B\", : \"C\" }"
    }
})

Jeg ved, at jeg har brugt strenge her. Men noget lignende kan også være muligt med ObjectIds. Prøv det venligst.




  1. Hvordan undgår man at to samtidige API-anmodninger bryder logikken bag dokumentvalidering?

  2. MongoDB C# foreach BsonElement

  3. Mongodb kan ikke finde objekt med for langt _id

  4. Importer data til dine nyoprettede MongoDB-instanser