วิธีเปลี่ยนชื่อฟิลด์ใน 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)

โปรดทราบว่า false, true ในฟังก์ชัน $rename หมายถึง {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 ในฟิลด์ คลาส ได้ถูกเปลี่ยนชื่อ เป็นแผนก ในแต่ละเอกสาร

หมายเหตุ : คุณสามารถค้นหาเอกสารฉบับเต็มสำหรับฟังก์ชัน $rename ได้ที่นี่

แหล่งข้อมูลเพิ่มเติม

บทช่วยสอนต่อไปนี้จะอธิบายวิธีดำเนินการทั่วไปอื่นๆ ใน MongoDB:

MongoDB: วิธีเพิ่มฟิลด์ใหม่
MongoDB: วิธีลบฟิลด์
MongoDB: วิธีนับค่าที่แตกต่างกันในฟิลด์

เพิ่มความคิดเห็น

อีเมลของคุณจะไม่แสดงให้คนอื่นเห็น ช่องข้อมูลจำเป็นถูกทำเครื่องหมาย *