Abfrageergebnisse abrufen

Nachdem Sie eine Abfrage erstellt haben, können Sie verschiedene Abrufoptionen festlegen, um die gelieferten Ergebnisse noch gezielter einzugrenzen. Weitere Informationen zum Strukturieren von Abfragen für Ihre Anwendung finden Sie unter Datastore-Abfragen.

Einzelne Entität abrufen

Zum Abrufen einer einzelnen Entität, die mit Ihrer Abfrage übereinstimmt, verwenden Sie die Methode Query.get() (oder GqlQuery.get()):

q = Person.all()
q.filter("last_name =", target_last_name)

result = q.get()

Dies gibt das erste Ergebnis im Index zurück, das mit der Abfrage übereinstimmt.

Abfrageergebnisse durchlaufen

Wenn Sie die Ergebnisse einer Abfrage mit der Methode run() eines Objekts vom Typ Query oder GqlQuery durchlaufen, ruft Cloud Datastore die Ergebnisse in Batches ab. Standardmäßig enthält jeder Batch 20 Ergebnisse. Sie können diesen Wert jedoch mit dem Parameter batch_size der Methode ändern. Sie können die Abfrageergebnisse durchlaufen, bis alle Ergebnisse zurückgegeben sind oder bis eine Zeitüberschreitung eintritt.

Ausgewählte Attribute einer Entität abrufen

Wenn Sie anstatt einer vollständigen Entität nur eine Auswahl der zugehörigen Attribute abrufen möchten, verwenden Sie eine Projektionsabfrage. Dieser Abfragetyp wird schneller ausgeführt und kostet weniger als Abfragen, die vollständige Entitäten zurückgeben.

Analog dazu können Sie mit ausschließlich schlüsselbasierten Abfragen Zeit und Ressourcen sparen, da nur die Schlüssel für die übereinstimmenden Entitäten zurückgegeben werden, nicht jedoch die vollständigen Entitäten. Legen Sie zum Erstellen dieses Abfragetyps keys_only=True fest, wenn Sie das Abfrageobjekt erstellen:

q = Person.all(keys_only=True)

Limits für Abfragen festlegen

Sie können ein Limit für die Abfrage festlegen, um die Anzahl der in einem Batch zurückgegebenen Ergebnisse zu begrenzen. Im folgenden Beispiel werden die fünf größten Personen aus Cloud Datastore abgerufen:

q = Person.all()
q.order("-height")

for p in q.run(limit=5):
  print "%s %s, %d inches tall" % (p.first_name, p.last_name, p.height)

Weitere Informationen

Hat Ihnen diese Seite weitergeholfen? Teilen Sie uns Ihr Feedback mit:

Feedback geben zu...

App Engine-Standardumgebung für Python 2