كيفية إعادة تسمية الحقول في mongodb (3 أمثلة)
يمكنك استخدام الطرق التالية لإعادة تسمية الحقول في MongoDB:
الطريقة الأولى: إعادة تسمية حقل
db.collection.updateMany({}, { $rename :{" oldField ":" newField "}}, false, true)
الطريقة الثانية: إعادة تسمية حقول متعددة
db.collection.updateMany({}, { $rename :{" old1 ":" new1 ", " old2 ":" new2 "}}, false, true)
الطريقة الثالثة: إعادة تسمية الحقل الفرعي
db.collection.updateMany({}, { $rename :{" field.oldSub ":" field.newSub "}}, 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: كيفية حساب القيم المميزة في الحقل