So benennen sie felder in mongodb um (3 beispiele)


Sie können die folgenden Methoden verwenden, um Felder in MongoDB umzubenennen:

Methode 1: Ein Feld umbenennen

 db.collection.updateMany({}, { $rename :{" oldField ":" newField "}}, false, true)

Methode 2: Mehrere Felder umbenennen

 db.collection.updateMany({}, { $rename :{" old1 ":" new1 ", " old2 ":" new2 "}}, false, true)

Methode 3: Benennen Sie das Unterfeld um

 db.collection.updateMany({}, { $rename :{" field.oldSub ":" field.newSub "}}, false, true)

Beachten Sie, dass „ false“, „true“ in der Funktion „$rename “ {upsert:false, multi:true} bedeutet.

Sie benötigen multi:true , um den Feldnamen in allen Ihren Dokumenten zu aktualisieren.

Die folgenden Beispiele zeigen, wie die einzelnen Methoden mit einem Inkassoteam mit den folgenden Dokumenten verwendet werden:

 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 })

Beispiel 1: Ein Feld umbenennen

Wir können den folgenden Code verwenden, um das Teamfeld in new_team umzubenennen:

 db.teams.updateMany({}, { $rename :{" team ":" new_team "}}, false, true)

So sehen die Dokumente jetzt aus:

 { _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' }

Beachten Sie, dass das Teamfeld für jedes Dokument in new_team umbenannt wurde.

Beispiel 2: Mehrere Felder umbenennen

Wir können den folgenden Code verwenden, um das Feld „team“ in „new_team “ und das Feld „ points“ in „ new_points“ umzubenennen:

 db.teams.updateMany({}, { $rename :{" team ":" new_team ", " points ":" new_points "}}, false, true)

So sehen die Dokumente jetzt aus:

 { _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 }

Beachten Sie, dass sowohl das Teamfeld als auch das Punktefeld in jedem Dokument umbenannt wurden.

Beispiel 3: Benennen Sie das Unterfeld um

Wir können den folgenden Code verwenden, um das div- Unterfeld im div- Klassenfeld umzubenennen:

 db.teams.updateMany({}, { $rename :{" class.div ":" class.division "}}, false, true)

So sehen die Dokumente jetzt aus:

 { _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 }

Beachten Sie, dass das Unterfeld „div“ im Feld „ class “ in jedem Dokument in „ division“ umbenannt wurde.

Hinweis : Die vollständige Dokumentation für die Funktion $rename finden Sie hier .

Zusätzliche Ressourcen

In den folgenden Tutorials wird erläutert, wie Sie andere gängige Vorgänge in MongoDB ausführen:

MongoDB: So fügen Sie ein neues Feld hinzu
MongoDB: So löschen Sie ein Feld
MongoDB: So zählen Sie unterschiedliche Werte in einem Feld

Einen Kommentar hinzufügen

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert