อ้างถึงสคีมาอื่นในพังพอน


104

ถ้าฉันมีสองสคีมาเช่น:

var userSchema = new Schema({
    twittername: String,
    twitterID: Number,
    displayName: String,
    profilePic: String,
});

var  User = mongoose.model('User') 

var postSchema = new Schema({
    name: String,
    postedBy: User,  //User Model Type
    dateCreated: Date,
    comments: [{body:"string", by: mongoose.Schema.Types.ObjectId}],
});

ฉันพยายามเชื่อมโยงเข้าด้วยกันเหมือนตัวอย่างด้านบน แต่คิดไม่ออกว่าจะทำอย่างไร ในที่สุดถ้าฉันสามารถทำอะไรแบบนี้ได้มันจะทำให้ชีวิตของฉันง่ายมาก

var profilePic = Post.postedBy.profilePic

คำตอบ:


182

ดูเหมือนว่าวิธีการเติมข้อมูลเป็นสิ่งที่คุณต้องการ ขั้นแรกให้ทำการเปลี่ยนแปลงเล็กน้อยกับสคีมาโพสต์ของคุณ:

var postSchema = new Schema({
    name: String,
    postedBy: {type: mongoose.Schema.Types.ObjectId, ref: 'User'},
    dateCreated: Date,
    comments: [{body:"string", by: mongoose.Schema.Types.ObjectId}],
});

จากนั้นสร้างแบบจำลองของคุณ:

var Post = mongoose.model('Post', postSchema);

จากนั้นเมื่อคุณสร้างแบบสอบถามคุณสามารถเติมข้อมูลอ้างอิงได้ดังนี้:

Post.findOne({_id: 123})
.populate('postedBy')
.exec(function(err, post) {
    // do stuff with post
});

4
ช่อง "อ้างอิง" มีไว้เพื่ออะไร? ฉันไม่พบเอกสารประกอบ
basickarl

3
ฟิลด์อ้างอิง @KarlMorrison หมายถึงคอลเล็กชันที่ระบุ ID ที่จะถูกค้นหา
Ankur Verma

อะไรคือความแตกต่างระหว่าง populate และ addToSet?
Winnemucca

1
อ้างอิงจากby:selectro
Muhammad Umer

1
@KarlMorrison เอกสารสำหรับ "อ้างอิง" ถูกฝังอยู่ในเอกสารสำหรับpopulate: mongoosejs.com/docs/populate.html
Jeffrey Martinez

19

ภาคผนวก: ไม่มีใครพูดถึง "Populate" --- มันคุ้มค่ามากกับเวลาและเงินของคุณเมื่อมองไปที่ Mongooses Populate Method: ยังอธิบายถึงการอ้างอิงเอกสารข้าม

http://mongoosejs.com/docs/populate.html


1

ตอบช้า แต่เสริมว่าพังพอนยังมีแนวคิดเรื่องSubdocuments

ด้วยไวยากรณ์นี้คุณควรจะสามารถอ้างอิงuserSchemaเป็นประเภทของคุณได้postSchema:

var userSchema = new Schema({
    twittername: String,
    twitterID: Number,
    displayName: String,
    profilePic: String,
});

var postSchema = new Schema({
    name: String,
    postedBy: userSchema,
    dateCreated: Date,
    comments: [{body:"string", by: mongoose.Schema.Types.ObjectId}],
});

หมายเหตุการปรับปรุงข้อมูลที่มีประเภทpostedByuserSchema

การดำเนินการนี้จะฝังออบเจ็กต์ของผู้ใช้ไว้ในโพสต์โดยบันทึกการค้นหาเพิ่มเติมที่จำเป็นโดยใช้ข้อมูลอ้างอิง บางครั้งสิ่งนี้อาจดีกว่าในบางครั้งเส้นทางการอ้างอิง / เติมข้อมูลอาจเป็นวิธีที่จะไป ขึ้นอยู่กับว่าแอปพลิเคชันของคุณกำลังทำอะไร

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.