Tài liệu về nhà → Hướng dẫn sử dụng MongoDB → MongoDB Manual
Trên trang này
- Truy vấn cho một tài liệu được lồng trong một mảng
- Chỉ định một điều kiện truy vấn trên trường trong một mảng tài liệu
- Chỉ định nhiều điều kiện cho mảng tài liệu
- Hướng dẫn truy vấn bổ sung
Sử dụng menu chọn ngôn ngữ của bạn ở phía trên bên phải để đặt ngôn ngữ của các ví dụ sau.Select your language drop-down menu in the upper-right to set the language of the following examples.
Ví dụ sau chọn tất cả các tài liệu trong đó một phần tử trong mảng instock
khớp với tài liệu được chỉ định:
Bình đẳng khớp với toàn bộ tài liệu nhúng/lồng nhau đòi hỏi một kết hợp chính xác của tài liệu được chỉ định, bao gồm cả thứ tự trường. Ví dụ: truy vấn sau không khớp với bất kỳ tài liệu nào trong bộ sưu tập inventory
:
Nếu bạn không biết vị trí chỉ mục của tài liệu được lồng trong mảng, hãy nối tên của trường mảng, với một dấu chấm [.
] và tên của trường trong tài liệu lồng nhau.
Ví dụ sau chọn tất cả các tài liệu trong đó mảng instock
có ít nhất một tài liệu nhúng có chứa trường qty
có giá trị nhỏ hơn hoặc bằng 20
:
Sử dụng ký hiệu DOT, bạn có thể chỉ định các điều kiện truy vấn cho trường trong tài liệu tại một chỉ mục hoặc vị trí cụ thể của mảng. Mảng sử dụng lập chỉ mục dựa trên không.
Ghi chú
Khi truy vấn sử dụng ký hiệu DOT, trường và chỉ mục phải ở bên trong dấu ngoặc kép.
Ví dụ sau chọn tất cả các tài liệu trong đó mảng instock
có phần tử đầu tiên là tài liệu chứa trường qty
có giá trị nhỏ hơn hoặc bằng 20
:
Khi chỉ định các điều kiện trên nhiều trường được lồng trong một mảng tài liệu, bạn có thể chỉ định truy vấn sao cho một tài liệu duy nhất đáp ứng các điều kiện này hoặc bất kỳ kết hợp tài liệu nào [bao gồm một tài liệu] trong mảng đáp ứng các điều kiện.
Sử dụng toán tử $elemMatch
để chỉ định nhiều tiêu chí trên một mảng các tài liệu nhúng sao cho ít nhất một tài liệu nhúng thỏa mãn tất cả các tiêu chí được chỉ định.
Các truy vấn ví dụ sau đây cho các tài liệu trong đó mảng instock
có ít nhất một tài liệu nhúng có chứa cả trường qty
bằng inventory
2 và trường inventory
3 bằng inventory
4:
Các truy vấn ví dụ sau đây cho các tài liệu trong đó mảng instock
có ít nhất một tài liệu nhúng có chứa trường qty
lớn hơn inventory
7 và nhỏ hơn hoặc bằng 20
:
Nếu các điều kiện truy vấn hợp chất trên trường mảng không sử dụng toán tử $elemMatch
, truy vấn sẽ chọn các tài liệu có mảng chứa bất kỳ sự kết hợp nào của các phần tử thỏa mãn các điều kiện.
Ví dụ: truy vấn sau phù hợp với các tài liệu trong đó bất kỳ tài liệu nào được lồng trong mảng instock
có trường qty
lớn hơn inventory
7 và bất kỳ tài liệu nào [nhưng không nhất thiết là cùng một tài liệu nhúng] trong mảng có trường qty
nhỏ hơn hoặc bằng 20
:
Các truy vấn ví dụ sau đây cho các tài liệu trong đó mảng instock
có ít nhất một tài liệu nhúng có chứa trường qty
bằng inventory
2 và ít nhất một tài liệu được nhúng [nhưng không nhất thiết là cùng một tài liệu nhúng] có chứa trường inventory
3 bằng inventory
4:
Để biết các ví dụ truy vấn bổ sung, xem:
Truy vấn một mảng
Tài liệu truy vấn
Truy vấn trên các tài liệu nhúng/lồng nhau
Tài liệu về nhà → Hướng dẫn sử dụng MongoDB → MongoDB Manual
Trên trang này
- Khớp với một mảng
- Truy vấn một mảng cho một phần tử
- Chỉ định nhiều điều kiện cho các phần tử mảng
- Hướng dẫn truy vấn bổ sung
Sử dụng menu chọn ngôn ngữ của bạn ở phía trên bên phải để đặt ngôn ngữ của các ví dụ sau.Select your language drop-down menu in the upper-right to set the language of the following examples.
Các truy vấn ví dụ sau đây cho tất cả các tài liệu trong đó giá trị trường instock
0 là một mảng có chính xác hai phần tử, instock
1 và instock
2, theo thứ tự được chỉ định:
Thay vào đó, nếu bạn muốn tìm một mảng chứa cả hai phần tử instock
1 và instock
2, mà không liên quan đến thứ tự hoặc các phần tử khác trong mảng, hãy sử dụng toán tử instock
5:
Các truy vấn ví dụ sau đây cho tất cả các tài liệu trong đó instock
0 là một mảng chứa chuỗi instock
1 là một trong các yếu tố của nó:
Ví dụ: các truy vấn hoạt động sau đây cho tất cả các tài liệu trong đó mảng instock
8 chứa ít nhất một phần tử có giá trị lớn hơn instock
9.
Khi chỉ định các điều kiện hợp chất trên các phần tử mảng, bạn có thể chỉ định truy vấn sao cho một phần tử mảng duy nhất đáp ứng các điều kiện này hoặc bất kỳ sự kết hợp nào của các phần tử mảng đáp ứng các điều kiện.
Các truy vấn ví dụ sau đây cho các tài liệu trong đó mảng instock
8 chứa các yếu tố trong một số kết hợp thỏa mãn các điều kiện truy vấn; ví dụ: một yếu tố có thể thỏa mãn điều kiện lớn hơn qty
1 và một phần tử khác có thể thỏa mãn điều kiện nhỏ hơn 20
hoặc một phần tử duy nhất có thể thỏa mãn cả hai:
Sử dụng toán tử $elemMatch
để chỉ định nhiều tiêu chí về các phần tử của một mảng sao cho ít nhất một phần tử mảng đáp ứng tất cả các tiêu chí được chỉ định.
Các truy vấn ví dụ sau đây cho các tài liệu trong đó mảng instock
8 chứa ít nhất một phần tử vừa hơn [qty
5] qty
6 và nhỏ hơn [qty
7] qty
8:
Sử dụng ký hiệu DOT, bạn có thể chỉ định các điều kiện truy vấn cho một phần tử tại một chỉ mục hoặc vị trí cụ thể của mảng. Mảng sử dụng lập chỉ mục dựa trên không.
Ghi chú
Khi truy vấn sử dụng ký hiệu DOT, trường và trường lồng nhau phải ở bên trong dấu ngoặc kép.
Các truy vấn ví dụ sau đây cho tất cả các tài liệu trong đó phần tử thứ hai trong mảng instock
8 lớn hơn instock
9:
Sử dụng toán tử 20
1 để truy vấn cho các mảng theo số phần tử. Ví dụ: các tài liệu chọn sau đây trong đó mảng instock
0 có 3 yếu tố.
Để biết các ví dụ truy vấn bổ sung, xem:
Tài liệu truy vấn
Truy vấn trên các tài liệu nhúng/lồng nhau
Truy vấn một loạt các tài liệu nhúng