Ne concerne que l'édition Cloud Firestore Enterprise. |
Cette page décrit les différences de comportement entre Cloud Firestore compatible avec MongoDB et MongoDB.
Pour obtenir la liste des fonctionnalités compatibles en fonction de la version de MongoDB, consultez les ressources suivantes :
- Fonctionnalités disponibles : 8.0
- Fonctionnalités compatibles : 7.0
- Fonctionnalités disponibles : 6.0
- Fonctionnalités disponibles : 5.0
Connexions et bases de données
- Chaque connexion est limitée à une seule base de données Cloud Firestore compatible avec MongoDB.
- Vous devez créer une base de données avant de vous y connecter.
Dénomination
Les différences suivantes s'appliquent à la dénomination des parties de votre modèle de données.
Collections
- Les noms de collections correspondant à
__.*__
ne sont pas acceptés.
Champs
- Les noms de champs correspondant à
__.*__
ne sont pas acceptés. - Les noms de champs vides ne sont pas acceptés.
Documents
- La taille maximale d'un document est de 4 Mio.
- La profondeur d'imbrication maximale des champs est de 20. Chaque champ de type Array et Object ajoute un niveau à la profondeur globale.
_id
- Le document
_id
(champ de premier niveau) doit être un ObjectId, une chaîne ou un entier de 64 bits. Les autres types BSON ne sont pas acceptés. - Les chaînes vides ("") et les valeurs 0 64 bits (0L) ne sont pas acceptées.
Valeurs
- Les types BSON JavaScript, Symbol, DBPointer et Undefined ne sont pas acceptés.
Date
- Les valeurs de date doivent être comprises dans
[0001-01-01T00:00:00Z, 9999-12-31T23:59:59Z]
.
Decimal128
- Les valeurs
NaN
, l'infini positif et l'infini négatif sont canonisées lors de l'écriture. - Les opérations arithmétiques sur Decimal128 ne sont pas acceptées.
Double
- Les valeurs
NaN
sont canonisées lors de l'écriture.
Expression régulière
- Les options d'expression régulière doivent être valides ("i", "m", "s", "u" ou "x") et fournies par ordre alphabétique, sans répétition.
Requêtes
- L'ordre de tri naturel (requêtes sans tri explicite) ne correspond pas à l'ordre d'insertion ni à l'ordre croissant de
_id
.
Agrégations
- Les agrégations sont limitées à 250 étapes.
- Les étapes
$merge
et$out
ne sont pas acceptées. Consultez la section Commandes pour obtenir la liste complète des étapes et des opérateurs compatibles. - L'étape
$lookup
se limite à spécifier unforeignField
sur_id
.
Écritures
- Les documents dont le nom commence par un signe dollar ("$") ne peuvent pas être créés à l'aide de la fonctionnalité d'insertion/mise à jour de
update
oufindAndModify
. - Assurez-vous que votre chaîne de connexion inclut
retryWrites=false
(ou utilisez la méthode appropriée à votre pilote) pour vous assurer que le pilote ne tente pas d'utiliser cette fonctionnalité. Les écritures pouvant faire l'objet d'une nouvelle tentative ne sont pas acceptées.
Transactions
L'isolation d'instantané et les transactions sérialisables sont acceptées.
Par défaut, les transactions utilisent des contrôles de simultanéité optimistes avec isolation d'instantané.
Lire les préoccupations
Cloud Firestore compatible avec MongoDB accepte les niveaux de cohérence de lecture
snapshot
,majority
etlinearizable
. La valeur par défaut estsnapshot
, qui fait référence à l'isolation des instantanés.Utilisez
linearizable
lorsque l'application nécessite une cohérence stricte et doit empêcher les anomalies de biais d'écriture. Pour les autres charges de travail,snapshot
peut améliorer les performances et réduire la contention des transactions.
Niveau de fiabilité de l'écriture
- Seuls les niveaux de fiabilité d'écriture
w: 'majority'
etw: 1
sont acceptés.
Préférence de lecture
- Seuls les niveaux de cohérence en lecture
primary
,primaryPreferred
,primary_preferred
,secondary_preferred
etnearest
sont acceptés.
Index
- Les index avec caractères génériques ne sont pas acceptés.
- Cloud Firestore compatible avec MongoDB ne crée pas automatiquement d'index sur
_id
, mais il garantit que les valeurs de_id
sont uniques dans une collection. - Les index pour lesquels la clé multiple n'est pas activée ne sont pas automatiquement convertis en index à clé multiple en fonction des opérations d'écriture. Vous devez activer la clé multiple lorsque vous créez l'index. Cette option ne peut pas être modifiée.
Erreurs
- Les codes et messages d'erreur peuvent différer entre Cloud Firestore compatible avec MongoDB et MongoDB.
Commandes
Les différences de comportement suivantes s'appliquent à des commandes spécifiques.
- Les commandes qui ne figurent pas dans les tableaux ci-dessous ne sont pas compatibles.
maxTimeMS
est accepté par la plupart des commandes, mais peut être ignoré.
Requêtes et écritures
Commande | Champs non acceptés |
---|---|
|
|
|
|
|
|
|
|
|
Dans une instruction DELETE :
|
|
|
|
|
|
|
|
|
|
(aucun) |
Transactions et sessions
Commande | Champs non acceptés |
---|---|
|
|
|
|
|
(aucun) |
Administration
Commande | Champs non acceptés | Remarques |
---|---|---|
|
|
filter doit être vide s'il est fourni. |
|
|
Si authorizedCollections est fourni, il doit être défini sur "false". |
|
|
|
|
|
Cette commande est une opération sans effet.capped doit être défini sur "false" s'il est fourni. |
Étape suivante
- Exécutez le guide de démarrage rapide : créer une base de données et s'y connecter.
- Pour obtenir la liste complète des fonctionnalités compatibles, consultez Types de données, pilotes et fonctionnalités MongoDB compatibles.