用于在字段中创建未知数量项目的文档的 Mongoose 最佳实践

Mongoose best practices for document creation with unknown number of items in a field

我左顾右盼,写了一些演示代码,写了一些测试来实现一个学校管理系统。

我想从更习惯 mongoose 开发的人那里知道的是,如何以一种方式创建此模式的最佳实践是如何从这个单一中添加尽可能多的地址和联系费用文档。

我是自己解决的,不知道是不是最优雅可行的方法,希望有经验的人给点意见​​。

我应该为地址、电子邮件和 phone 号码创建单独的模型吗?

我创建了这个架构。它仍然有一些伪代码,但是给出一般的想法是好的。

var student = {
    name: String, 
    surname: String, 
    currentClass: {
        type: mongoose.Schema.Types.ObjectId, 
        ref: "Classes"
    }, 
    birthday: {
        year: Number,
        month: Number,
        day: Number
    },
    address: [{
        name: String, 
        zip: Number,
        address: String, 
        city: String, 
        state: String, 
        complement: String
    }]
    accountable: {
        name: String, 
        surname: String, 
        email: [{
            type: String, 
            required: true, 
            lowercase: true
        }], 
    phone: [String, String]
}

我的解决方案是,通过使用 html,创建一个新的 "email" 或 "address" 字段,正如用户通过点击右上角按钮所请求的那样。这生成了一个新的输入字段,其名称遵循如下模式: 电子邮件 1、电子邮件 2、电子邮件 3、电子邮件 4

因此,当用户发送数据时,如果我们要创建一个新学生,我会先用数据创建数组并将其发送到 mongoose。

在更新的情况下,我会获取已经创建的电子邮件并将其添加到带有 newEmails.concat(old_emails)

的新数组中

要设计数据库,有很多种情况: 1对1,1对多,多对多。
一对一:你应该把强物放在另一个里面,例如:
一个人只能有一本护照,那么我们应该把护照物件放在人里面目的。 一对多,一对多3例。
One to Few:few是少于100个对象,那么你应该在one对象中添加the few as list,例如: 如上例所示,一个人可以有多个地址。
One to Many:many是Thousands,那么你应该把many的主键放在one对象里面的列表里。 One to Too many: 那就不要做之前的方案了,而是在many的每一个objects中加上one的primary。
最后,多对多:你应该把它们作为列表放在两边。
检查以下参考资料:
https://www.mongodb.com/blog/post/6-rules-of-thumb-for-mongodb-schema-design-part-1
https://www.mongodb.com/blog/post/6-rules-of-thumb-for-mongodb-schema-design-part-2
https://www.mongodb.com/blog/post/6-rules-of-thumb-for-mongodb-schema-design-part-3


此外,这部分phone: [String, String],你应该做到phone: [String]