gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 10:42:11 32 4
gpt4 key购买 nike

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

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

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

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

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

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,创建一个新的“电子邮件”或“地址”字段,正如用户通过点击右上角的按钮所请求的那样。这生成了一个新的输入字段,其名称遵循如下模式:电子邮件 1、电子邮件 2、电子邮件 3、电子邮件 4

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

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

的新数组中

最佳答案

要设计数据库,有很多种情况:1对1、1对多、多对多。
一对一:应该把强对象放在另一个里面,例如:
一个人只能有一本护照,那么我们应该把护照对象放在人对象里面。一对多,一对多3例。
One to Few:few是少于100个objects,那么你应该在one object中添加the few as list,例如:如上例所示,一个人可以有多个地址。
一对多:many就是Thousands,那么你应该把many的主键放在one对象里面的一个列表中。One to Too many:那就不做前面的解法,而是在多的每个对象中加上一个的主。
最后,多对多:你应该把它们作为列表放在两边。
检查以下引用资料:
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]

关于node.js - 用于在字段中创建未知数量项目的文档的 Mongoose 最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37836013/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com