

As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.

# \$1nin
<a name="nin"></a>

O `$nin` operador é usado para combinar valores que não estão na matriz especificada. É o inverso do `$in` operador, que corresponde aos valores que estão na matriz especificada.

A versão 2.0 do Planner adicionou suporte de índice para`$nin`.

**Parâmetros**
+ `field`: O campo a ser verificado.
+ `array`: a matriz de valores a serem comparados.

 

**Dólar (`$`) em nomes de campo**

Consulte as limitações [Dólar (\$1) e ponto (.) nos nomes dos campos](functional-differences.md#functional-differences-dollardot) relacionadas à consulta de campos `$` prefixados `$nin` em objetos aninhados.

## Exemplo (MongoDB Shell)
<a name="nin-examples"></a>

O exemplo a seguir demonstra como usar o `$nin` operador para encontrar documentos em que o `category` campo não é igual a “Ficção” ou “Mistério”.

**Crie documentos de amostra**

```
db.books.insertMany([
  { title: "The Great Gatsby", author: "F. Scott Fitzgerald", category: "Fiction" },
  { title: "To Kill a Mockingbird", author: "Harper Lee", category: "Fiction" },
  { title: "The Girl on the Train", author: "Paula Hawkins", category: "Mystery" },
  { title: "The Martian", author: "Andy Weir", category: "Science Fiction" },
  { title: "The Alchemist", author: "Paulo Coelho", category: "Philosophy" }
])
```

**Exemplo de consulta**

```
db.books.find({
  category: {
    $nin: ["Fiction", "Mystery"]
  }
})
```

**Saída**

```
[
  {
    _id: ObjectId('...'),
    title: 'The Martian',
    author: 'Andy Weir',
    category: 'Science Fiction'
  },
  {
    _id: ObjectId('...'),
    title: 'The Alchemist',
    author: 'Paulo Coelho',
    category: 'Philosophy'
  }
]
```

## Exemplos de código
<a name="nin-code"></a>

Para ver um exemplo de código para usar o `$nin` comando, escolha a guia do idioma que você deseja usar:

------
#### [ Node.js ]

```
const { MongoClient } = require('mongodb');

async function findBooksNotInCategories(categories) {
  const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false');
  const db = client.db('test');
  const books = await db.collection('books').find({
    category: {
      $nin: categories
    }
  }).toArray();
  console.log(books);
  client.close();
}

findBooksNotInCategories(['Fiction', 'Mystery']);
```

------
#### [ Python ]

```
from pymongo import MongoClient

def find_books_not_in_categories(categories):
    client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false')
    db = client['test']
    books = list(db.books.find({
        'category': {
            '$nin': categories
        }
    }))
    print(books)
    client.close()

find_books_not_in_categories(['Fiction', 'Mystery'])
```

------