Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
$lookup
Tahap $lookup agregasi di Amazon DocumentDB memungkinkan Anda melakukan gabungan luar kiri antara dua koleksi. Operasi ini memungkinkan Anda menggabungkan data dari beberapa koleksi berdasarkan nilai bidang yang cocok. Ini sangat berguna ketika Anda perlu memasukkan data dari koleksi terkait ke dalam hasil kueri Anda.
Parameter
-
from: Nama koleksi untuk melakukan bergabung dengan. -
localField: Bidang dari dokumen masukan untuk mencocokkan denganforeignField. -
foreignField: Bidang dari dokumen dalamfromkoleksi untuk dicocokkan denganlocalField. -
as: Nama bidang baru untuk ditambahkan ke dokumen keluaran yang berisi dokumen yang cocok darifromkoleksi.
Contoh (MongoDB Shell)
Contoh berikut menunjukkan $lookup operasi sederhana yang menggabungkan data dari orders koleksi ke dalam koleksi. customers
Buat dokumen sampel
db.customers.insertMany([ { _id: 1, name: "Alice" }, { _id: 2, name: "Bob" }, { _id: 3, name: "Charlie" } ]); db.orders.insertMany([ { _id: 1, customer_id: 1, total: 50 }, { _id: 2, customer_id: 1, total: 100 }, { _id: 3, customer_id: 2, total: 75 } ]);
Contoh kueri
db.customers.aggregate([ { $lookup: { from: "orders", localField: "_id", foreignField: "customer_id", as: "orders" } } ]);
Keluaran
[
{
_id: 1,
name: 'Alice',
orders: [
{ _id: 2, customer_id: 1, total: 100 },
{ _id: 1, customer_id: 1, total: 50 }
]
},
{ _id: 3, name: 'Charlie', orders: [] },
{
_id: 2,
name: 'Bob',
orders: [ { _id: 3, customer_id: 2, total: 75 } ]
}
]
Contoh kode
Untuk melihat contoh kode untuk menggunakan $lookup perintah, pilih tab untuk bahasa yang ingin Anda gunakan: