Présentation de l'indexation
Les index sont un facteur important de performances pour une base de données. Tout comme le sommaire d'un livre qui indique la correspondance des sujets avec des numéros de page, l'index d'une base de données associe les éléments qu'elle contient à leur emplacement. Lorsque vous effectuez une requête une base de données, celle-ci peut utiliser un index pour identifier rapidement les emplacements les articles que vous avez demandés.
Cette page décrit les deux types d'index utilisés par Firestore : les index à champ unique et les index composites.
Définition et structure des index
Un index est défini sur une liste de champs d'un document donné, avec un mode d'index correspondant pour chaque champ.
Un index contient une entrée pour chaque champ nommé dans la définition de l'index. L'index inclut tous les documents qui constituent des résultats potentiels pour les requêtes basées sur l'index. Un document n'est inclus dans l'index que s'il a une valeur indexée défini pour chaque champ utilisé dans l'index. Si la définition de l'index fait référence à un champ pour lequel aucune valeur n'est définie dans le document, ce document n'apparaîtra pas dans l'index. Dans ce cas, le document ne sera jamais renvoyé en tant que résultat pour une requête basée sur l'index.
L'index composite est trié par valeurs de champ, dans l'ordre spécifié dans les définition de l'index.
Un index derrière chaque requête
Si aucun index n'est disponible pour une requête, la plupart des bases de données parcourent un à un les éléments qu'elles contiennent. Ce processus devient de plus en plus lent à mesure que la base de données s'agrandit. Pour garantir des performances de requêtes élevées, Firestore fait appel à des index pour toutes les requêtes. Ainsi, les performances des requêtes dépendent de la taille de l'ensemble de résultats et non du nombre d'éléments disponibles dans la base de données.
Une gestion d'index aisée pour développer plus rapidement
Firestore inclut des fonctionnalités qui vous permettent de consacrer moins de temps à gérer des index. Les index requis pour les fonctions les plus élémentaires sont créées automatiquement. Firestore vous aide à identifier et à créer d'autres index requis à mesure que vous utilisez et testez votre application.
Types d'index
Firestore utilise deux types d'index : les index à champ unique et les index composites. Outre le nombre de champs indexés, les index à champ unique et les index composites diffèrent dans la façon dont vous les gérez.
Index à champ unique
Un index à champ unique stocke un tri de correspondances entre tous les documents d'une collection qui contiennent un seul champ spécifique. Chaque entrée d'un index à champ unique enregistre la valeur d'un document pour un champ spécifique ainsi que l'emplacement du document dans la base de données. Firestore exécute de nombreuses requêtes élémentaires à l'aide de ces index. Pour gérer les index à champ unique, vous devez configurer les paramètres d'indexation automatique et les exceptions d'index de votre base de données.
Indexation automatique
Par défaut, Firestore conserve automatiquement des index à champ unique pour chaque champ d'un document et chaque sous-champ d'une carte. Pour les index à champ unique, Firestore utilise les paramètres par défaut suivants :
Pour chaque champ non issu d'un tableau ou d'une carte, Firestore crée deux index à champ unique dont le champ d'application est défini sur une collection, l'un en mode croissant et l'autre en mode décroissant.
Pour chaque champ de mappage, Firestore crée les éléments suivants:
- Un index croissant dont le champ d'application est défini sur une collection pour chaque sous-champ qui ne correspond pas à un tableau ni à une carte.
- Un index décroissant dont le champ d'application est défini sur une collection pour chaque sous-champ non issu d'un tableau ou d'une carte.
- Un index "array-contains" de portée collection pour chaque sous-champ de tableau.
- Firestore indexe de manière récursive chaque sous-champ de mappage.
Pour chaque champ de tableau d'un document, Firestore crée et conserve un index "array-contains" dont le champ d'application est défini sur une collection.
Les index à champ unique dont le champ d'application est défini sur un groupe de collections ne sont pas conservés par défaut.
Exceptions d'index à champ unique
Vous pouvez exclure un champ de vos paramètres d'indexation automatique en créant une exception d'index à champ unique. Les exceptions d'indexation vous permettent de remplacer les paramètres d'index automatiques de votre base de données. Une exception permet d'activer un index à champ unique qui était à l'origine désactivé par vos paramètres d'indexation automatiques. À l'inverse, vous pouvez désactiver un index à champ unique qui était à l'origine activé par l'indexation automatique. Pour découvrir dans quelles situations utiliser les exceptions, consultez les bonnes pratiques en matière d'indexation.
Utilisez la valeur de chemin d'accès du champ *
pour ajouter des exceptions d'index au niveau de la collection sur tous
dans un groupe de collections. Par exemple, pour le groupe de collections comments
, définissez le chemin d'accès au champ sur *
pour faire correspondre tous les champs du groupe de collections comments
et désactivez l'indexation de tous les champs du groupe de collections. Vous pouvez ensuite ajouter
pour n'indexer que les champs requis pour vos requêtes. Réduire la valeur
le nombre de champs indexés réduit les coûts de stockage et peut améliorer l'écriture
des performances.
Si vous créez une exception d'index à champ unique pour un champ de carte, les sous-champs de la carte héritent de ces paramètres. Vous pouvez toutefois définir des exceptions d'index à champ unique pour des sous-champs spécifiques. Si vous supprimez une exception pour un sous-champ, le sous-champ hérite des paramètres d'exception de son parent, s'ils existent. Si aucune exception n'existe pour le parent, le sous-champ hérite des paramètres de base de données.
Pour créer et gérer des exceptions d'index à champ unique, consultez la page Gérer les index.
Index composites
Un index composite stocke un tri de correspondances entre tous les documents d'une collection, en fonction d'une liste numérotée de champs à indexer.
Firestore utilise des index composites pour traiter les requêtes qui ne sont pas déjà prises en charge par des index à champ unique.
Firestore ne crée pas automatiquement d'index composites de ce type pour les index à champ unique en raison du grand nombre de champs possibles combinaisons. Firestore vous aide toutefois à identifier et créer les index composites requis à mesure que vous développez votre application.
Chaque fois que vous essayez d'envoyer une requête non prise en charge par un index, Firestore renvoie un message d'erreur avec un lien que vous pouvez suivre pour créer l'index manquant.
Vous pouvez aussi définir et gérer manuellement des index composites à l'aide de la console ou de l'interface en ligne de commandes CLI Firebase. Pour découvrir comment créer et gérer des index composites, consultez la page Gérer les index.
Modes d'index et champs d'application des requêtes
Même si la configuration des index à champ unique diffère de celle des index composites, vous devez configurer les modes d'index et les champs d'application des requêtes pour les deux types d'index.
Modes d'index
Lorsque vous définissez un index, vous sélectionnez un mode d'index pour chaque champ indexé. Le mode d'index de chaque champ accepte des clauses de requête spécifiques à ce champ. Vous pouvez choisir parmi les modes d'index suivants :
Mode d'index | Description |
---|---|
Croissant | Le champ accepte les clauses de requête < , <= , == , >= , > , != , in et not-in , et les résultats sont triés par ordre croissant en fonction de la valeur de ce champ. |
Décroissant | Le champ accepte les clauses de requête < , <= , == , >= , > , != , in et not-in , et les résultats sont triés par ordre décroissant en fonction de la valeur de ce champ. |
Array‑contains | Le champ accepte les clauses de requête array-contains et array-contains-any . |
Vector | Le champ accepte les clauses de requête FindNearest . |
Champs d'application des requêtes
Chaque index s'applique à une collection ou à un groupe de collections. C'est ce qu'on appelle le champ d'application des requêtes d'index :
- Champ d'application de la collection
- Par défaut, Firestore crée des index qui s'appliquent à une collection. Ces index acceptent les requêtes qui renvoient les résultats d'une seule collection.
- Champ d'application du groupe de collections
- Un groupe de collections inclut toutes les collections possédant le même identifiant. Pour obtenir des résultats filtrés ou triés d'un groupe de collections lorsque vous exécutez une requête de groupe de collections, vous devez créer un index correspondant qui s'applique au groupe de collections.
Ordre par défaut et champ __name__
En plus de trier les documents en fonction des modes d'indexation spécifiés pour chaque champ (ascendant ou descendant), les index appliquent un tri final en fonction du champ __name__
de chaque document. La valeur de __name__
est défini sur le chemin d'accès complet du document. Cela signifie que les documents du jeu de résultats ayant les mêmes valeurs de champ sont triés par chemin d'accès au document.
Par défaut, le champ __name__
est trié dans la même direction que le dernier
dans un champ trié dans la
définition de l'index. Exemple :
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
cities | Nom de __name__ |
, Collection |
cities | État __name__ |
, Collection |
cities | __name__ |
pays, habitants, Collection |
Pour trier les résultats en fonction de la direction __name__
non par défaut, vous devez créer cet indice.
Propriétés de l'index
Un index permettant une exécution plus efficace de la requête est défini par les propriétés suivantes:
- Champs utilisés dans les filtres d'égalité
- Champs utilisés dans les ordres de tri
- Champs utilisés dans les filtres de plage et d'inégalité (qui ne sont pas déjà inclus dans les ordres de tri)
- Champs utilisés dans les agrégations (qui ne sont pas déjà inclus dans les ordres de tri et les filtres de plage et d'inégalité)
Firestore calcule les résultats des requêtes comme suit :
- Identifie l'index correspondant à la collection de la requête, aux propriétés du filtre, aux opérateurs de filtre et aux ordres de tri.
- Identifie la position d'index à partir de laquelle la numérisation commence. La position de départ est précédée des filtres d'égalité de la requête et se termine par les filtres de plage et d'inégalité du premier champ
orderBy
. - Il commence à analyser l'index, en renvoyant chaque document qui répond à tous les filtres, jusqu'à ce que le processus d'analyse effectue l'une des opérations suivantes :
- Rencontre un document qui ne remplit pas les conditions de filtre et confirme qu'aucun document ultérieur ne les remplira jamais complètement.
- Atteins la fin de l'index.
- Collecte le nombre maximal de résultats demandés par la requête.
Exemple d'indexation
Firestore crée automatiquement des index à champ unique, ce qui permet à votre application de prendre en charge rapidement les requêtes de bases de données les plus simples.
Les index à champ unique vous permettent d'effectuer des requêtes simples à partir des valeurs des champs et des comparateurs <
, <=
, ==
, >=
, >
et in
. Pour les champs de tableau, les index à champ unique vous permettent d'effectuer des requêtes array-contains
et array-contains-any
.
Examinez les exemples suivants qui illustrent les index à champ unique du point de vue de leur création. L'extrait de code suivant permet de créer des documents city
dans une collection cities
et de définir les champs name
, state
, country
, capital
, population
et tags
pour chaque document :
Web
var citiesRef = db.collection("cities"); citiesRef.doc("SF").set({ name: "San Francisco", state: "CA", country: "USA", capital: false, population: 860000, regions: ["west_coast", "norcal"] }); citiesRef.doc("LA").set({ name: "Los Angeles", state: "CA", country: "USA", capital: false, population: 3900000, regions: ["west_coast", "socal"] }); citiesRef.doc("DC").set({ name: "Washington, D.C.", state: null, country: "USA", capital: true, population: 680000, regions: ["east_coast"] }); citiesRef.doc("TOK").set({ name: "Tokyo", state: null, country: "Japan", capital: true, population: 9000000, regions: ["kanto", "honshu"] }); citiesRef.doc("BJ").set({ name: "Beijing", state: null, country: "China", capital: true, population: 21500000, regions: ["jingjinji", "hebei"] });
Firestore devine les paramètres d'indexation automatiques par défaut afin de mettre à jour un index à champ unique croissant et un index à champ unique décroissant pour chaque champ non issu d'un tableau, ainsi qu'un index à champ unique "array-contains" pour le champ de tableau. Chaque ligne du tableau suivant représente une entrée dans un index à champ unique :
Collection | Champ indexé | Champ d'application de la requête |
---|---|---|
cities | name | Collection |
cities | state | Collection |
cities | country | Collection |
cities | capital | Collection |
cities | population | Collection |
cities | name | Collection |
cities | state | Collection |
cities | country | Collection |
cities | capital | Collection |
cities | population | Collection |
cities | array-contains regions |
Collection |
Requêtes acceptées par les index à champ unique
À l'aide de ces index à champ unique créés automatiquement, vous pouvez exécuter des requêtes simples comme suit :
Web
const stateQuery = citiesRef.where("state", "==", "CA"); const populationQuery = citiesRef.where("population", "<", 100000); const nameQuery = citiesRef.where("name", ">=", "San Francisco");
Vous pouvez également créer des requêtes in
et des requêtes d'égalité composées (==
) :
Web
citiesRef.where('country', 'in', ["USA", "Japan", "China"]) // Compound equality queries citiesRef.where("state", "==", "CO").where("name", "==", "Denver") citiesRef.where("country", "==", "USA") .where("capital", "==", false) .where("state", "==", "CA") .where("population", "==", 860000)
Si vous devez exécuter une requête composée en comparant des plages (<
, <=
, >
ou >=
) ou si vous devez trier les résultats en fonction d'un autre champ, vous devez créer un index composite pour cette requête.
L'index array-contains
vous permet d'interroger le champ de tableau regions
:
Web
citiesRef.where("regions", "array-contains", "west_coast") // array-contains-any and array-contains use the same indexes citiesRef.where("regions", "array-contains-any", ["west_coast", "east_coast"])
Requêtes acceptées par les index composites
Firestore utilise des index composites pour accepter les requêtes composées qui ne sont pas déjà prises en charge par les index à champ unique. Par exemple, les requêtes suivantes nécessitent un index composite :
Web
citiesRef.where("country", "==", "USA").orderBy("population", "asc") citiesRef.where("country", "==", "USA").where("population", "<", 3800000) citiesRef.where("country", "==", "USA").where("population", ">", 690000) // in and == clauses use the same index citiesRef.where("country", "in", ["USA", "Japan", "China"]) .where("population", ">", 690000)
Ces requêtes nécessitent d'utiliser l'index composite ci-dessous. Étant donné que la requête utilise une clause d'égalité (==
ou in
) pour le champ country
, vous pouvez utiliser un mode d'index croissant ou décroissant pour ce champ. Par défaut, les clauses d'inégalité appliquent un ordre de tri croissant en fonction du champ qu'elles concernent.
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
cities | (ou ) country, population | Collection |
Pour exécuter les mêmes requêtes avec un ordre de tri décroissant, vous devez créer un index composite supplémentaire en appliquant le sens décroissant à population
:
Web
citiesRef.where("country", "==", "USA").orderBy("population", "desc") citiesRef.where("country", "==", "USA") .where("population", "<", 3800000) .orderBy("population", "desc") citiesRef.where("country", "==", "USA") .where("population", ">", 690000) .orderBy("population", "desc") citiesRef.where("country", "in", ["USA", "Japan", "China"]) .where("population", ">", 690000) .orderBy("population", "desc")
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
cities | country, population | Collection |
cities | country, population | Collection |
Pour éviter toute perte de performances causée par la fusion d'index, nous vous recommandons de créer
Un index composite pour combiner une requête array-contains
ou array-contains-any
avec des clauses supplémentaires:
Web
citiesRef.where("regions", "array-contains", "east_coast") .where("capital", "==", true) // array-contains-any and array-contains use the same index citiesRef.where("regions", "array-contains-any", ["west_coast", "east_coast"]) .where("capital", "==", true)
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
cities | tags array-contains, | (ou ) capitalCollection |
Requêtes acceptées par les index de groupes de collections
Pour illustrer un index dont le champ d'application est défini sur un groupe de collections, ajoutez une
Sous-collection landmarks
vers certains des documents city
:
Web
var citiesRef = db.collection("cities"); citiesRef.doc("SF").collection("landmarks").doc().set({ name: "Golden Gate Bridge", category : "bridge" }); citiesRef.doc("SF").collection("landmarks").doc().set({ name: "Golden Gate Park", category : "park" }); citiesRef.doc("DC").collection("landmarks").doc().set({ name: "National Gallery of Art", category : "museum" }); citiesRef.doc("DC").collection("landmarks").doc().set({ name: "National Mall", category : "park" });
Cet index à champ unique dont le champ d'application est défini sur une collection vous permet d'interroger la collection landmarks
d'une seule ville en fonction du champ category
:
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
landmarks | (ou ) category | Collection |
Web
citiesRef.doc("SF").collection("landmarks").where("category", "==", "park") citiesRef.doc("SF").collection("landmarks").where("category", "in", ["park", "museum"])
Si vous souhaitez interroger les points de repère de toutes les villes, par exemple,
vous exécutez cette requête sur le groupe de collections qui se compose de tous les landmarks
.
des collections. Vous devez également activer un index à champ unique landmarks
avec
Champ d'application du groupe de collections:
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
landmarks | (ou ) category | Groupe de collections |
Lorsque cet index est activé, vous pouvez interroger le groupe de collections landmarks
:
Web
var landmarksGroupRef = db.collectionGroup("landmarks"); landmarksGroupRef.where("category", "==", "park") landmarksGroupRef.where("category", "in", ["park", "museum"])
Pour obtenir des résultats filtrés ou triés lorsque vous exécutez une requête de groupe de collections, vous devez activer un index à champ unique ou composite correspondant qui s'applique au groupe de collections. En revanche, si une requête de groupe de collections n'exige pas de trier ou de filtrer les résultats, aucun autre index n'est nécessaire.
Par exemple, vous pouvez exécuter la requête de groupe de collections suivante sans activer d'index supplémentaire :
Web
db.collectionGroup("landmarks").get()
Entrées d'index
Les index configurés de votre projet et la structure d'un document déterminent le nombre d'entrées d'index pour un document. Les entrées d'index sont comptabilisées dans la limite du nombre d'entrées d'index.
L'exemple suivant illustre les entrées d'index d'un document.
Document
/cities/SF
city_name : "San Francisco"
temperatures : {summer: 67, winter: 55}
neighborhoods : ["Mission", "Downtown", "Marina"]
Index à champ unique
- city_name ASC
- city_name DESC
- températures.été ASC
- temperatures.summer DESC
- températures.winter ASC
- températures.winter DESC
- neighborhoods Array Contains (ASC et DESC)
Index composites
- city_name ASC, neighborhoods ARRAY
- city_name DESC, neighborhoods ARRAY
Entrées d'index
Cette configuration d'indexation génère les entrées d'index suivantes pour le paramètre document:
Index | Données indexées |
---|---|
Entrées d'index à champ unique | |
city_name ASC | city_name: "San Francisco" |
city_name DESC | city_name: "San Francisco" |
temperatures.summer ASC | temperatures.summer: 67 |
températures.été DESC | temperatures.summer: 67 |
temperatures.winter ASC | temperatures.winter: 55 |
temperatures.winter DESC | temperatures.winter: 55 |
quartiers Tableau Contient ASC | neighborhoods: "Mission" |
quartiers Le tableau contient DESC | neighborhoods: "Mission" |
quartiers Tableau Contient ASC | neighborhoods: "Downtown" |
quartiers Le tableau contient DESC | neighborhoods: "Downtown" |
neighborhoods Array Contains ASC | neighborhoods: "Marina" |
neighborhoods Array Contains DESC | neighborhoods: "Marina" |
Entrées d'index composite | |
city_name ASC, quartiers ARRAY | city_name: "San Francisco", neighborhoods: "Mission" |
city_name ASC, quartiers ARRAY | city_name: "San Francisco", neighborhoods: "Downtown" |
city_name ASC, quartiers ARRAY | city_name: "San Francisco", quartiers : "Marina" |
city_name DESC, quartiers ARRAY | city_name: "San Francisco", quartiers : "Mission" |
city_name DESC, quartiers ARRAY | city_name: "San Francisco", neighborhoods: "Downtown" |
city_name DESC, quartiers ARRAY | city_name: "San Francisco", quartiers : "Marina" |
Index et tarifs
Les coûts de stockage de votre application prennent en compte les index. Pour en savoir plus sur le calcul de la taille de l'espace de stockage des index, consultez Taille des entrées d'index.
Utiliser la fusion d'index
Bien que chaque requête effectuée dans Firestore utilise un index, il n'est pas nécessaire d'avoir recours à un index unique par requête. Pour les requêtes comportant plusieurs clauses d'égalité (==
) et, éventuellement, une clause orderBy
, Firestore peut réutiliser des index existants. Firestore est capable de fusionner les index des requêtes d'égalité simples pour créer les index composites requis lorsque vous effectuez des requêtes d'égalité plus volumineuses.
Vous pouvez réduire les coûts d'indexation en identifiant les cas d'utilisation de l'index
de la fusion. Par exemple, dans une collection restaurants
pour une application de notation de restaurants :
restaurants
burgerthyme
name : "Burger Thyme"
category : "burgers"
city : "San Francisco"
editors_pick : true
star_rating : 4
Cette application utilise des requêtes comme celles-ci. L'application utilise des combinaisons d'égalité.
pour category
, city
et editors_pick
, tout en triant par
star_rating
dans l'ordre croissant:
Web
db.collection("restaurants").where("category", "==", "burgers") .orderBy("star_rating") db.collection("restaurants").where("city", "==", "San Francisco") .orderBy("star_rating") db.collection("restaurants").where("category", "==", "burgers") .where("city", "==", "San Francisco") .orderBy("star_rating") db.collection("restaurants").where("category", "==", "burgers") .where("city", "==" "San Francisco") .where("editors_pick", "==", true ) .orderBy("star_rating")
Vous pourriez créer un index pour chaque requête :
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
restaurants | category, star_rating | Collection |
restaurants | city, star_rating | Collection |
restaurants | category, city, star_rating | Collection |
restaurants | category, city, editors_pick, star_rating | Collection |
Toutefois, une solution plus efficace consiste à réduire le nombre d'index à l'aide de la fusion d'index pour les clauses d'égalité permise par Firestore :
Collection | Champs indexés | Champ d'application de la requête |
---|---|---|
restaurants | category, star_rating | Collection |
restaurants | city, star_rating | Collection |
restaurants | editors_pick, star_rating | Collection |
Non seulement cet ensemble d'index est plus petit, mais il accepte également une requête supplémentaire :
Web
db.collection("restaurants").where("editors_pick", "==", true) .orderBy("star_rating")
Limites d'indexation
Les limites suivantes s'appliquent aux index. Pour en savoir plus sur les quotas et les limites, consultez Quotas et limites.
Cette page présente les quotas et limites de requêtes concernant Firestore.
Limite | Détails |
---|---|
Nombre maximal d'index composites pour une base de données |
|
Nombre maximal de configurations à champ unique pour une base de données |
Une configuration au niveau du champ peut contenir plusieurs configurations pour le même champ. Par exemple : une exception d'indexation à champ unique et une règle TTL (Time To Live) pour le même champ compte comme une configuration de champ dans le calcul de la limite. |
Nombre maximal d'entrées d'index pour chaque document |
40 000 Le nombre d'entrées d'index représente la somme des entrées suivantes pour un document :
Pour savoir comment Firestore transforme un document et un ensemble d'index en entrées d'index, consultez cet exemple de nombre d'entrées d'index. |
Nombre maximal de champs dans un index composite | 100 |
Taille maximale d'une entrée d'index |
7,5 Kio Pour savoir comment Firestore calcule la taille des entrées d'index, consultez la page Taille des entrées d'index. |
Somme maximale des tailles d'entrée d'index d'un document |
8 Mio La taille totale représente la somme des tailles suivantes pour un document : |
Taille maximale d'une valeur de champ indexé |
1 500 octets Les valeurs de champ au-delà de 1 500 octets sont tronquées. Les requêtes impliquant des valeurs de champ tronquées peuvent renvoyer des résultats incohérents. |
Bonnes pratiques d'indexation
Pour la plupart des applications, vous pouvez compter sur l'indexation automatique et sur les liens affichés dans les messages d'erreur pour gérer vos index. Toutefois, les cas suivants peuvent nécessiter l'ajout d'exceptions de champs uniques :
Cas | Description |
---|---|
Champs de chaîne volumineux | S'il existe un champ de chaîne contenant souvent des chaînes longues que vous n'utilisez pas pour les requêtes, vous pouvez réduire les coûts de stockage en excluant le champ de l'indexation. |
Taux d'écriture élevés dans une collection contenant des documents avec des valeurs séquentielles | Si vous indexez un champ qui augmente ou diminue séquentiellement entre les documents d'une collection, comme un horodatage, le taux d'écriture maximal pour la collection est de 500 écritures par seconde. Si vous ne faites pas de requête en fonction du champ avec des valeurs séquentielles, vous pouvez exclure le champ de l'indexation pour contourner cette limite. Par exemple, dans le cas d'un IoT avec un taux d'écriture élevé, une collection contenant des documents avec un champ d'horodatage peut approcher la limite des 500 écritures par seconde. |
Champs TTL |
Si vous utilisez des règles TTL (Time To Live), notez que le champ TTL doit être un code temporel. L'indexation sur les champs TTL est activée par défaut et peut affecter les performances à des taux de trafic plus élevés. Nous vous recommandons d'ajouter des exceptions de champ unique pour vos champs TTL. |
Champs de tableau ou de carte volumineux | Les champs de tableau ou de mappage volumineux peuvent approcher la limite de 40 000 entrées d'index par document. Si vous ne faites pas de requête en fonction d'un champ de tableau ou de carte volumineux, vous devez exclure ce champ de l'indexation. |
Si vous utilisez des requêtes avec des opérateurs de plage et d'inégalité sur plusieurs champs, consultez les considérations d'indexation à prendre en compte pour optimiser les performances et les coûts des requêtes Firestore.
Pour savoir comment résoudre les problèmes d'indexation (fanout d'index, erreurs INVALID_ARGUMENT
), consultez la page de dépannage.