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 function တွင် 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 class အကွက်တွင် div subfield ကို အမည်ပြောင်းရန် အောက်ပါကုဒ်ကို အသုံးပြုနိုင်ပါသည်။

 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- အကွက်တစ်ခုတွင် ကွဲပြားသောတန်ဖိုးများကို ရေတွက်နည်း

မှတ်ချက်တစ်ခုထည့်ပါ။

သင့် email လိပ်စာကို ဖော်ပြမည် မဟုတ်ပါ။ လိုအပ်သော ကွက်လပ်များကို * ဖြင့်မှတ်သားထားသည်