Blog

Database Reference trong MongoDB

Như đã được trình bày trong chương Relationship trong MongoDB, để triển khai một cấu trúc cơ sở dữ liệu tiêu chuẩn hóa trong MongoDB, chúng ta sử dụng khái niệm Referenced Relationship, còn được gọi là Manual References, trong đó chúng ta thao tác để lưu giữ id của các Document được tham chiếu bên trong Document khác. Tuy nhiên, trong các trường hợp mà một Document chứa nhiều tham chiếu từ các Collection khác nhau, thì chúng ta sử dụng DBRefs trong MongODB.

DBRefs và Manual References

Trong ví dụ sau, chúng ta sẽ sử dụng DBRefs thay cho Manual References. Giả sử có một Database chúng ta dùng để lưu giữ các kiểu địa chỉ khác nhau (home, office, mailing,…) trong các Collection khác nhau (address_home, address_office, address_mailing,…). Bây giờ, khi một user collection tham chiếu một địa chỉ, nó cũng cần xác định xem collection nào nó sẽ nhìn vào, dựa trên kiểu địa chỉ. Trong tình huống như vậy, khi một Document tham chiếu tới Document khác từ nhiều Collection, chúng ta nên sử dụng DBRefs.

Sử dụng DBRefs trong MongoDB

Có 3 trường trong DBRefs:

$ref: Trường này xác định Collection của Document được tham chiếu.

$id: Trường này xác định trường _id của Document được tham chiếu.

$db: Trường này là một trường tùy ý, chứa tên của Database mà Document được tham chiếu ở trong đó.

Giả sử một user document có trường address dạng DBRefs như sau:

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

Trường address dạng DBRefs ở đây xác định rằng address document được tham chiếu ở trong address_home collection dưới tutorialspoint database và có một id là: 534009e4d852427820000002.

Phần code sau sẽ nhìn vào Collection được xác định bởi tham số $ref (là address_home trong trường hợp này) cho một Document với id được xác định bởi tham số $id trong DBRefs.

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

Code trên trả về address document sau đây, mà có mặt trong address_home collection:

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

Nguồn: Internet

Chúng tôi chuyên cung cấp những khóa học về Phân tích dữ liệu, đăng ký ngay để nhận được tư vấn chi tiết lộ trình dành riêng cho bạn nhé!

    LIÊN HỆ VỚI CHÚNG TÔI ĐỂ NHẬN ĐƯỢC TƯ VẤN MIỄN PHÍ
    Xin vui lòng điền vào form dưới đây. Chúng tôi sẽ liên hệ lại ngay cho bạn khi nhận được thông tin:






    Leave a Reply

    Your email address will not be published. Required fields are marked *