

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

# \$1slice
<a name="slice-projection"></a>

Der `$slice` Projektionsoperator begrenzt die Anzahl der Array-Elemente, die in einem Abfrageergebnis zurückgegeben werden. Er ermöglicht es Ihnen, eine bestimmte Anzahl von Elementen vom Anfang oder Ende eines Array-Felds abzurufen, ohne das gesamte Array zu laden.

**Parameter**
+ `field`: Das zu projizierende Array-Feld.
+ `count`: Anzahl der zurückzugebenden Elemente. Positive Werte geben Elemente vom Anfang zurück, negative Werte vom Ende.

## Beispiel (MongoDB Shell)
<a name="slice-projection-examples"></a>

Das folgende Beispiel zeigt, wie der `$slice` Projektionsoperator verwendet wird, um nur die ersten beiden Elemente aus einem Array-Feld zurückzugeben.

**Erstellen Sie Beispieldokumente**

```
db.inventory.insertMany([
  { _id: 1, item: "notebook", tags: ["office", "school", "supplies", "writing"] },
  { _id: 2, item: "pen", tags: ["office", "writing"] },
  { _id: 3, item: "folder", tags: ["office", "supplies", "storage", "organization"] }
]);
```

**Beispiel für eine Abfrage**

```
db.inventory.find(
  {},
  { item: 1, tags: { $slice: 2 } }
)
```

**Ausgabe**

```
{ "_id" : 1, "item" : "notebook", "tags" : [ "office", "school" ] }
{ "_id" : 2, "item" : "pen", "tags" : [ "office", "writing" ] }
{ "_id" : 3, "item" : "folder", "tags" : [ "office", "supplies" ] }
```

## Codebeispiele
<a name="slice-projection-code"></a>

Um ein Codebeispiel für die Verwendung des `$slice` Projektionsoperators anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten:

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

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

async function example() {
  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 collection = db.collection('inventory');

  const result = await collection.find(
    {},
    { projection: { item: 1, tags: { $slice: 2 } } }
  ).toArray();

  console.log(JSON.stringify(result, null, 2));
  await client.close();
}

example();
```

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

```
from pymongo import MongoClient

def example():
    client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false')
    db = client['test']
    collection = db['inventory']

    result = list(collection.find(
        {},
        {'item': 1, 'tags': {'$slice': 2}}
    ))

    print(result)
    client.close()

example()
```

------