MongoDB - odwołania do baz danych

Jak widać w ostatnim rozdziale relacji MongoDB, aby zaimplementować znormalizowaną strukturę bazy danych w MongoDB, używamy koncepcji Referenced Relationships określane również jako Manual Referencesw którym ręcznie przechowujemy identyfikator przywoływanego dokumentu w innym dokumencie. Jednak w przypadkach, gdy dokument zawiera odniesienia z różnych kolekcji, możemy użyćMongoDB DBRefs.

DBRefs vs Manual References

Jako przykładowy scenariusz, w którym użylibyśmy DBRefs zamiast ręcznych odwołań, rozważmy bazę danych, w której przechowujemy różne typy adresów (dom, biuro, korespondencja itp.) W różnych kolekcjach (adres_home, adres_biura, adres_poczta itp.). Teraz, kiedyuserdokument kolekcji odwołuje się do adresu, musi również określić, do której kolekcji należy spojrzeć na podstawie typu adresu. W takich scenariuszach, w których dokument odwołuje się do dokumentów z wielu kolekcji, powinniśmy używać DBRefs.

Korzystanie z DBRefs

W DBRefs są trzy pola -

  • $ref - To pole określa zbiór dokumentu, do którego się odwołuje

  • $id - To pole określa pole _id dokumentu, do którego się odwołuje

  • $db - Jest to pole opcjonalne i zawiera nazwę bazy danych, w której znajduje się dokument odniesienia

Rozważmy przykładowy dokument użytkownika zawierający pole DBRef address jak pokazano we fragmencie kodu -

{
   "_id":ObjectId("53402597d852426020000002"),
   "address": {
   "$ref": "address_home",
   "$id": ObjectId("534009e4d852427820000002"),
   "$db": "tutorialspoint"},
   "contact": "987654321",
   "dob": "01-01-1991",
   "name": "Tom Benzamin"
}

Plik address Pole DBRef w tym miejscu określa, że ​​przywoływany dokument adresowy znajduje się w address_home kolekcja pod tutorialspoint bazy danych i ma identyfikator 534009e4d852427820000002.

Poniższy kod dynamicznie wygląda w kolekcji określonej przez $ref parametr (address_home w naszym przypadku) dla dokumentu o identyfikatorze określonym przez $id parametr w DBRef.

>var user = db.users.findOne({"name":"Tom Benzamin"})
>var dbRef = user.address
>db[dbRef.$ref].findOne({"_id":(dbRef.$id)})

Powyższy kod zwraca następujący dokument adresowy obecny w address_home kolekcja -

{
   "_id" : ObjectId("534009e4d852427820000002"),
   "building" : "22 A, Indiana Apt",
   "pincode" : 123456,
   "city" : "Los Angeles",
   "state" : "California"
}