Questa pagina illustra le limitazioni relative alle query Datastore da Google App Engine. Il seguente elenco riporta le limitazioni comuni che incontrerai durante lo sviluppo per Datastore.
Le entità prive di una proprietà denominata nella query vengono ignorate
Le entità dello stesso tipo non devono avere le stesse proprietà. Per essere idonea come risultato di una query, un'entità deve avere un valore (possibilmente nullo) per ogni proprietà denominata nei filtri e negli ordinamenti della query. In caso contrario, l'entità viene omessa dagli indici utilizzati per eseguire la query e di conseguenza non verrà inclusa nei risultati della query.
Il filtro in base alle proprietà non indicizzate non restituisce risultati
Una query non può trovare valori di proprietà non indicizzati né ordinare in base a queste proprietà. Consulta la pagina Indici Datastore per una discussione dettagliata sulle proprietà non indicizzate.
I filtri di disuguaglianza sono limitati a una sola proprietà
Per evitare di dover scansionare l'intero indice, il meccanismo di query si basa sul fatto che tutti i potenziali risultati di una query siano adiacenti nell'indice. Per soddisfare questo vincolo, una singola query non può utilizzare confronti di disuguaglianza (LESS_THAN
, LESS_THAN_OR_EQUAL
, GREATER_THAN
, GREATER_THAN_OR_EQUAL
, NOT_EQUAL
) su più di una proprietà in tutti i suoi filtri. Ad esempio, la seguente query è valida perché entrambi i filtri di disuguaglianza si applicano alla stessa proprietà:
Tuttavia, questa query non è valida perché utilizza filtri di disuguaglianza su due proprietà diverse:
Tieni presente che una query può combinare filtri di uguaglianza (EQUAL
) per proprietà diverse, insieme a uno o più filtri di disuguaglianza su una singola proprietà. Pertanto, la seguente query è valida:
L'ordinamento dei risultati della query non è definito quando non viene specificato alcun ordine di ordinamento
Quando una query non specifica un ordine di ordinamento, i risultati vengono restituiti nell'ordine in cui vengono recuperati. Man mano che l'implementazione di Datastore si evolve (o se gli indici di un'applicazione cambiano), questo ordine potrebbe cambiare. Pertanto, se la tua applicazione richiede i risultati della query in un ordine particolare, assicurati di specificare esplicitamente l'ordine di ordinamento nella query.
Gli ordinamenti vengono ignorati nelle proprietà con filtri di uguaglianza
Le query che includono un filtro di uguaglianza per una determinata proprietà ignorano qualsiasi ordine di ordinamento specificato per quella proprietà. Si tratta di una semplice ottimizzazione per evitare l'elaborazione non necessaria per le proprietà a valore singolo, poiché tutti i risultati hanno lo stesso valore per la proprietà e quindi non è necessario alcun ulteriore ordinamento. Le proprietà con più valori, tuttavia, possono avere valori aggiuntivi oltre a quello corrispondente al filtro di uguaglianza. Poiché questo caso d'uso è raro e l'applicazione dell'ordinamento sarebbe costosa e richiederebbe indici aggiuntivi, il pianificatore di query Datastore ignora semplicemente l'ordinamento anche nel caso di valori multipli. Ciò potrebbe causare la restituzione dei risultati della query in un ordine diverso da quello che sembra implicito nell'ordinamento.
Le proprietà utilizzate nei filtri di disuguaglianza devono essere ordinate per prime
Per recuperare tutti i risultati che corrispondono a un filtro di disuguaglianza, una query esegue la scansione dell'indice per trovare la prima riga corrispondente al filtro, quindi continua la scansione finché non incontra una riga non corrispondente. Affinché le righe consecutive comprendano l'intero insieme di risultati, devono essere ordinate in base alla proprietà utilizzata nel filtro di disuguaglianza prima di qualsiasi altra proprietà. Pertanto, se una query specifica uno o più filtri di disuguaglianza insieme a uno o più ordini di ordinamento, il primo ordine di ordinamento deve fare riferimento alla stessa proprietà denominata nei filtri di disuguaglianza. Di seguito è riportata una query valida:
Questa query non è valida perché non esegue l'ordinamento in base alla proprietà utilizzata nel filtro di disuguaglianza:
Allo stesso modo, questa query non è valida perché la proprietà utilizzata nel filtro di disuguaglianza non è la prima ordinata:
Le proprietà con più valori possono comportarsi in modo sorprendente
A causa del modo in cui vengono indicizzate, le entità con più valori per la stessa proprietà a volte possono interagire con i filtri query e gli ordinamenti in modi inaspettati e sorprendenti.
Se una query ha più filtri di disuguaglianza su una determinata proprietà, un'entità corrisponderà alla query solo se almeno uno dei suoi singoli valori per la proprietà soddisfa tutti i filtri. Ad esempio, se un'entità di tipo Widget
ha i valori 1
e 2
per la proprietà x
, non corrisponderà alla query:
Ciascuno dei valori x
dell'entità soddisfa uno dei filtri, ma nessuno dei singoli valori li soddisfa entrambi. Tieni presente che questo non vale per i filtri di uguaglianza. Ad esempio, la stessa entità soddisferà la query
anche se nessuno dei singoli valori x
dell'entità soddisfa entrambe le condizioni di filtro.
L'operatore NOT_EQUAL
funziona come un test "il valore è diverso da". Ad esempio, la query
corrisponde a qualsiasi entità Widget
con un valore x
diverso da 1
.
In Java, puoi anche utilizzare una query come
che funge da
x < 1 OR (x > 1 AND x < 2) OR x > 2Pertanto, un'entità Widget
con i valori x
1
, 2
e 3
corrisponde, ma una con i valori
1
e 2
no.
Allo stesso modo, l'ordine di ordinamento per le proprietà con più valori è insolito. Poiché queste proprietà vengono visualizzate una volta nell'indice per ogni valore univoco, il primo valore visualizzato nell'indice determina l'ordine di ordinamento di un'entità:
- Se i risultati della query sono ordinati in ordine crescente, per l'ordinamento viene utilizzato il valore più piccolo della proprietà.
- Se i risultati sono ordinati in ordine decrescente, per l'ordinamento viene utilizzato il valore più alto.
- Gli altri valori non influiscono sull'ordinamento, né sul numero di valori.
Ciò ha la conseguenza insolita che un'entità con i valori delle proprietà 1
e 9
precede un'entità con i valori 4
, 5
, 6
e 7
sia in ordine crescente che decrescente.
Le query all'interno delle transazioni devono includere filtri predecessore
Le transazioni Datastore operano solo su entità appartenenti allo stesso gruppo di entità (discendenti da un antenato comune). Per mantenere questa limitazione, tutte le query eseguite all'interno di una transazione devono includere un filtro di antenati che specifichi un antenato nello stesso gruppo di entità delle altre operazioni nella transazione.