- Exemplo 1: Mudar o nome de um campo
- Exemplo 2: Mudar o nome de vários campos
- Exemplo 3: Renomear subcampo
Pode utilizar os seguintes métodos para renomear campos no MongoDB:
Método 1: Mudar o nome de um campo
db.collection.updateMany({}, { $rename :{" oldField ":" newField "}}, false, true)
Método 2: Mudar o nome de vários campos
db.collection.updateMany({}, { $rename :{" old1 ":" new1 ", " old2 ":" new2 "}}, false, true)
Método 3: Mudar o nome do subcampo
db.collection.updateMany({}, { $rename :{" field.oldSub ":" field.newSub "}}, false, true)
Note-se que o falso, verdadeiro na função $rename significa {upsert:false, multi:true} .
É necessário o multi:verdadeiro para atualizar o nome do campo em todos os seus documentos.
Os exemplos seguintes mostram como utilizar cada método com uma equipa de recolha com os seguintes documentos:
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"},pontos: 33 }) db.teams.insertOne({team: "Nets", class: {conf: "Eastern", div: "D"}, points: 38 })
Exemplo 1: Mudar o nome de um campo
Podemos usar o seguinte código para renomear o equipa campo para nova_equipa :
db.teams.updateMany({}, { $rename :{" team ":" new_team "}}, false, true)
Eis o aspeto atual dos documentos:
{ _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' }
Repare que o equipa foi renomeado para nova_equipa para cada documento.
Exemplo 2: Mudar o nome de vários campos
Podemos usar o seguinte código para renomear o equipa campo para nova_equipa e o pontos campo para novos_pontos :
db.teams.updateMany({}, { $rename :{" team ":" new_team ", " points ":" new_points "}}, false, true)
Eis o aspeto atual dos documentos:
{ _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 }
Repare que o equipa e o campo pontos foram ambos renomeados em cada documento.
Exemplo 3: Renomear subcampo
Podemos usar o seguinte código para renomear o div dentro do subcampo classe campo para divisão :
db.teams.updateMany({}, { $rename :{" class.div ":" class.division "}}, false, true)
Eis o aspeto atual dos documentos:
{ _id: ObjectId("62017e21fd435937399d6b5e"), equipa: 'Mavs', classe: { conf: 'Western', divisão: 'A' }, pontos: 31 } { _id: ObjectId("62017e21fd435937399d6b5f"), equipa: 'Spurs', classe: { conf: 'Western', divisão: 'A' }, pontos: 22 } { _id: ObjectId("62017e21fd435937399d6b60"), equipa: 'Jazz', classe: { conf: 'Western', divisão: 'B' }, pontos: 19 } { _id: ObjectId("62017e21fd435937399d6b61"), equipa:'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 }
Repare que o div dentro do subcampo classe foi renomeado para divisão em cada documento.
Nota : Pode encontrar a documentação completa para o $renomear função aqui.