Comment renommer des champs dans MongoDB (3 exemples)
Vous pouvez utiliser les méthodes suivantes pour renommer les champs dans MongoDB :
Méthode 1 : Renommer un champ
db.collection.updateMany({}, {$rename:{"oldField":"newField"}}, false, true)
Méthode 2 : Renommer plusieurs champs
db.collection.updateMany({}, {$rename:{"old1":"new1", "old2":"new2"}}, false, true)
Méthode 3 : Renommer le sous-champ
db.collection.updateMany({}, {$rename:{"field.oldSub":"field.newSub"}}, false, true)
Notez que le false, true dans la fonction $rename signifie {upsert:false, multi:true} .
Vous avez besoin du multi:true pour mettre à jour le nom du champ dans tous vos documents.
Les exemples suivants montrent comment utiliser chaque méthode avec une équipe de collecte avec les documents suivants :
db.teams.insertOne({team: "Mavs", class: {conf:"Western", div:"A"}, points: 31})
db.teams.insertOne({team: "Spurs", class: {conf:"Western", div:"A"}, points: 22})
db.teams.insertOne({team: "Jazz", class: {conf:"Western", div:"B"}, points: 19})
db.teams.insertOne({team: "Celtics", class: {conf:"Eastern", div:"C"}, points: 26})
db.teams.insertOne({team: "Cavs", class: {conf:"Eastern", div:"D"}, points: 33})
db.teams.insertOne({team: "Nets", class: {conf:"Eastern", div:"D"}, points: 38})
Exemple 1 : Renommer un champ
Nous pouvons utiliser le code suivant pour renommer le champ team en new_team :
db.teams.updateMany({}, {$rename:{"team":"new_team"}}, false, true)
Voici à quoi ressemblent les documents maintenant :
{ _id: ObjectId("62017ce6fd435937399d6b58"),
class: { conf: 'Western', div: 'A' },
points: 31,
new_team: 'Mavs' }
{ _id: ObjectId("62017ce6fd435937399d6b59"),
class: { conf: 'Western', div: 'A' },
points: 22,
new_team: 'Spurs' }
{ _id: ObjectId("62017ce6fd435937399d6b5a"),
class: { conf: 'Western', div: 'B' },
points: 19,
new_team: 'Jazz' }
{ _id: ObjectId("62017ce6fd435937399d6b5b"),
class: { conf: 'Eastern', div: 'C' },
points: 26,
new_team: 'Celtics' }
{ _id: ObjectId("62017ce6fd435937399d6b5c"),
class: { conf: 'Eastern', div: 'D' },
points: 33,
new_team: 'Cavs' }
{ _id: ObjectId("62017ce6fd435937399d6b5d"),
class: { conf: 'Eastern', div: 'D' },
points: 38,
new_team: 'Nets' }
Notez que le champ équipe a été renommé new_team pour chaque document.
Exemple 2 : Renommer plusieurs champs
Nous pouvons utiliser le code suivant pour renommer le champ team en new_team et le champ points en new_points :
db.teams.updateMany({}, {$rename:{"team":"new_team", "points":"new_points"}}, false, true)
Voici à quoi ressemblent les documents maintenant :
{ _id: ObjectId("62017ce6fd435937399d6b58"),
class: { conf: 'Western', div: 'A' },
new_team: 'Mavs',
new_points: 31 }
{ _id: ObjectId("62017ce6fd435937399d6b59"),
class: { conf: 'Western', div: 'A' },
new_team: 'Spurs',
new_points: 22 }
{ _id: ObjectId("62017ce6fd435937399d6b5a"),
class: { conf: 'Western', div: 'B' },
new_team: 'Jazz',
new_points: 19 }
{ _id: ObjectId("62017ce6fd435937399d6b5b"),
class: { conf: 'Eastern', div: 'C' },
new_team: 'Celtics',
new_points: 26 }
{ _id: ObjectId("62017ce6fd435937399d6b5c"),
class: { conf: 'Eastern', div: 'D' },
new_team: 'Cavs',
new_points: 33 }
{ _id: ObjectId("62017ce6fd435937399d6b5d"),
class: { conf: 'Eastern', div: 'D' },
new_team: 'Nets',
new_points: 38 }
Notez que le champ équipe et le champ points ont tous deux été renommés dans chaque document.
Exemple 3 : Renommer le sous-champ
Nous pouvons utiliser le code suivant pour renommer le sous-champ div dans le champ de classe en division :
db.teams.updateMany({}, {$rename:{"class.div":"class.division"}}, false, true)
Voici à quoi ressemblent les documents maintenant :
{ _id: ObjectId("62017e21fd435937399d6b5e"),
team: 'Mavs',
class: { conf: 'Western', division: 'A' },
points: 31 }
{ _id: ObjectId("62017e21fd435937399d6b5f"),
team: 'Spurs',
class: { conf: 'Western', division: 'A' },
points: 22 }
{ _id: ObjectId("62017e21fd435937399d6b60"),
team: 'Jazz',
class: { conf: 'Western', division: 'B' },
points: 19 }
{ _id: ObjectId("62017e21fd435937399d6b61"),
team: 'Celtics',
class: { conf: 'Eastern', division: 'C' },
points: 26 }
{ _id: ObjectId("62017e21fd435937399d6b62"),
team: 'Cavs',
class: { conf: 'Eastern', division: 'D' },
points: 33 }
{ _id: ObjectId("62017e21fd435937399d6b63"),
team: 'Nets',
class: { conf: 'Eastern', division: 'D' },
points: 38 }
Notez que le sous-champ div dans le champ classe a été renommé division dans chaque document.
Remarque : Vous pouvez trouver la documentation complète de la fonction $rename ici .
Ressources additionnelles
Les didacticiels suivants expliquent comment effectuer d’autres opérations courantes dans MongoDB :
MongoDB : Comment ajouter un nouveau champ
MongoDB : Comment supprimer un champ
MongoDB : Comment compter les valeurs distinctes dans un champ
