Mongodb에서 필드 이름을 바꾸는 방법(예제 3개)


다음 방법을 사용하여 MongoDB에서 필드 이름을 바꿀 수 있습니다.

방법 1: 필드 이름 바꾸기

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

방법 2: 여러 필드의 이름 바꾸기

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

방법 3: 하위 필드 이름 바꾸기

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

$rename 함수의 false, true는 {upsert:false, multi:true}를 의미합니다.

모든 문서의 필드 이름을 업데이트하려면 multi:true가 필요합니다.

다음 예는 다음 문서를 가지고 수집 과 함께 각 방법을 사용하는 방법을 보여줍니다.

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

예 1: 필드 이름 바꾸기

다음 코드를 사용하여 필드의 이름을 new_team 으로 바꿀 수 있습니다.

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

현재 문서는 다음과 같습니다.

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

각 문서에 대해 필드의 이름이 new_team 으로 변경되었습니다.

예 2: 여러 필드 이름 바꾸기

다음 코드를 사용하여 필드의 이름을 new_team 으로 바꾸고 포인트 필드의 이름을 new_points 로 바꿀 수 있습니다.

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

현재 문서는 다음과 같습니다.

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

각 문서에서 필드와 포인트 필드의 이름이 모두 변경되었습니다.

예 3: 하위 필드 이름 바꾸기

다음 코드를 사용하여 div 클래스 필드에서 div 하위 필드의 이름을 바꿀 수 있습니다.

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

현재 문서는 다음과 같습니다.

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

클래스 필드의 div 하위 필드는 각 문서에서 Division으로 이름이 변경되었습니다.

참고 : $rename 함수에 대한 전체 문서는 여기에서 찾을 수 있습니다.

추가 리소스

다음 튜토리얼에서는 MongoDB에서 다른 일반적인 작업을 수행하는 방법을 설명합니다.

MongoDB: 새 필드를 추가하는 방법
MongoDB: 필드를 삭제하는 방법
MongoDB: 필드에서 고유한 값을 계산하는 방법

의견을 추가하다

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다