MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Correction de "$pullAll nécessite un argument de tableau mais a reçu un double" dans MongoDB

Si vous obtenez le "$pullAll nécessite un argument de tableau mais a reçu un double ” erreur dans MongoDB, c'est parce que vous n'avez pas fourni de tableau comme valeur à remplacer.

Exemple

Supposons que nous ayons une collection avec les documents suivants :

{ "_id" : 1, "bar" : [ 1, 7, 2, 3, 8, 7, 1 ] }
{ "_id" : 2, "bar" : [ 0, 1, 8, 17, 18, 8 ] }
{ "_id" : 3, "bar" : [ 15, 11, 8, 0, 1, 3 ] }

Et nous voulons utiliser $pullAll pour remplacer toutes les occurrences d'une valeur dans l'un de ces documents.

Code du problème

Voici un exemple de code qui provoque l'erreur ci-dessus :

db.foo.update( 
  { _id: 1 }, 
  { $pullAll: { bar: 7 } } 
)

Résultat :

WriteResult({
	"nMatched" : 0,
	"nUpserted" : 0,
	"nModified" : 0,
	"writeError" : {
		"code" : 2,
		"errmsg" : "$pullAll requires an array argument but was given a double"
	}
})

Cela s'est produit parce que nous avons oublié d'entourer la valeur 7 avec crochets. En d'autres termes, nous avons oublié de fournir un tableau.

Solution

Voici le même code sauf que cette fois nous avons fourni la valeur sous forme de tableau :

db.foo.update( 
  { _id: 1 }, 
  { $pullAll: { bar: [ 7 ] } } 
)

Résultat :

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

Cela nous montre qu'un document a été mis en correspondance et modifié.

Jetons un coup d'œil à la collection maintenant :

db.foo.find()

Résultat :

{ "_id" : 1, "bar" : [ 1, 2, 3, 8, 1 ] }
{ "_id" : 2, "bar" : [ 0, 1, 8, 17, 18, 8 ] }
{ "_id" : 3, "bar" : [ 15, 11, 8, 0, 1, 3 ] }

Le document a été mis à jour avec succès.