Menu Docs
Página inicial do Docs
/ / /
Node.js
/ / /

Especifique quais campos retornar

Nesta página

  • Visão geral
  • Documentos de amostra
  • Campo Único
  • Vários campos

Use uma projeção para controlar quais campos aparecem nos documentos retornados pelas operações de leitura. Muitas solicitações exigem apenas determinados campos, portanto, as projeções podem ajudar a limitar o uso desnecessário da largura de banda da rede. As projeções funcionam de duas formas:

  • Inclua campos explicitamente com um valor de 1. Isso tem o efeito colateral de excluir implicitamente todos os campos não especificados.

  • Exclua implicitamente campos com valor 0. Isso tem o efeito colateral de incluir implicitamente todos os campos não especificados.

Esses dois métodos de projeção são mutuamente exclusivos: se você incluir campos explicitamente, não poderá excluir campos explicitamente e vice-versa.

Para acompanhar os exemplos deste guia, use o seguinte trecho de código para inserir documentos que descrevem frutas na coleção myDB.fruits :

const myDB = client.db("myDB");
const myColl = myDB.collection("fruits");
await myColl.insertMany([
{ "_id": 1, "name": "apples", "qty": 5, "rating": 3 },
{ "_id": 2, "name": "bananas", "qty": 7, "rating": 1 },
{ "_id": 3, "name": "oranges", "qty": 6, "rating": 2 },
{ "_id": 4, "name": "avocados", "qty": 3, "rating": 5 },
]);

Observação

Sua operação de query pode retornar uma referência a um cursor que contém documentos correspondentes. Para saber como examinar os dados armazenados no cursor, consulte a página Fundamentos do cursor.

Na query a seguir, passe a projeção para retornar somente o campo name de cada documento:

// return only* the name field
const projection = { name: 1 };
const cursor = myColl.find().project(projection);
for await (const doc of cursor) {
console.dir(doc);
}

O documento de projeção especifica um valor de 1 para name para indicar que o resultado da operação de leitura deve incluir o campo name de cada documento gerado. Como resultado, esta projeção exclui implicitamente os campos qty e rating . Passar essa projeção para find() com um query vazio e nenhum documento de classificação produz os seguintes resultados:

{ "_id": 1, "name": "apples" }
{ "_id": 2, "name": "bananas" }
{ "_id": 3, "name": "oranges" }
{ "_id": 4, "name": "avocados" }

Apesar do fato de que essa projeção só incluía explicitamente o campo name , a query retornou o campo _id também!

Isso acontece porque o campo _id é um caso especial: ele sempre é incluído em todas as queries, a menos que seja explicitamente especificado de outra forma. Isso porque o _id é um identificador exclusivo para cada documento, uma propriedade que pode ser muito útil ao construir queries. A coleção movies é um bom exemplo da utilidade dessa propriedade: como as refilmagens e até mesmo os trabalhos separados podem, às vezes, reutilizar títulos de filmes, você precisa de um valor _id exclusivo para se referir a qualquer filme específico. _id é a única exceção ao comportamento mutuamente exclusivo de incluir-excluir em projeções: você pode excluir explicitamente _id mesmo ao incluir explicitamente outros campos se não quiser que _id esteja presente nos documentos retornados.

// return only the name field
const projection = { _id: 0, name: 1 };
const cursor = myColl.find().project(projection);
for await (const doc of cursor) {
console.dir(doc);
}

O documento de projeção especifica um valor de 1 para name para indicar que o resultado da operação de leitura deve incluir o campo name de cada documento gerado. Como resultado, esta projeção exclui implicitamente os campos qty e rating . Passar essa projeção para find() com um query vazio e nenhum documento de classificação produz os seguintes resultados:

{ "name": "apples" }
{ "name": "bananas" }
{ "name": "oranges" }
{ "name": "avocados" }

Você também pode especificar vários campos para incluir em sua projeção. Observação: a ordem em que você especifica os campos na projeção não altera a ordem em que eles são retornados.

const projection = { _id: 0, rating: 1, name: 1 };
const cursor = myColl.find().project(projection);
for await (const doc of cursor) {
console.dir(doc);
}

Este exemplo que identifica dois campos a serem incluídos na projeção gera os seguintes resultados:

{ "name": "apples", "rating": 3 }
{ "name": "bananas", "rating": 1 }
{ "name": "oranges", "rating": 2 }
{ "name": "avocados", "rating": 5 }

Para obter exemplos de projeção adicionais, consulte a página Manual do MongoDB em Campos do projeto a serem retornados da query.

← Limite o número de resultados retornados