

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

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

L'`$nin`operatore viene utilizzato per abbinare valori che non sono presenti nell'array specificato. È l'inverso dell'`$in`operatore, che corrisponde ai valori presenti nell'array specificato.

La versione 2.0 di Planner ha aggiunto il supporto per gli indici per. `$nin`

**Parametri**
+ `field`: Il campo da controllare.
+ `array`: La matrice di valori da confrontare.

 

**Dollar (`$`) nei nomi dei campi**

Vedi le limitazioni [Dollar (\$1) e dot (.) nei nomi dei campi](functional-differences.md#functional-differences-dollardot) relative all'interrogazione di campi con `$` prefisso `$nin` negli oggetti annidati.

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

L'esempio seguente mostra come utilizzare l'`$nin`operatore per trovare documenti in cui il `category` campo non è uguale a «Fiction» o «Mystery».

**Crea documenti di esempio**

```
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" }
])
```

**Esempio di interrogazione**

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

**Output**

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

## Esempi di codice
<a name="nin-code"></a>

Per visualizzare un esempio di codice per l'utilizzo del `$nin` comando, scegliete la scheda relativa alla lingua che desiderate utilizzare:

------
#### [ 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'])
```

------