- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在 NodeJS 中开发一个使用 MongoDB 的演示应用程序,当前使用的模块是 Express 和 Mongoose。
主要思想是重新制作一个 PHP+MySQL 应用程序,其中 MySQL 数据库由三个表组成,采用 1:N 关系:Company->Field->Item
示例数据收集如下所示:
[
{"id": 1,"name": "DemoCompanyOne", "fields":[
{"id": 1, "location": "DemoLocationOne", "items":[
{"_id": 1,"name": "DemoItemOne","price": 1500,"count": 16,"date": "2013-11-02 16:53:19"},
{"_id": 2,"name": "DemoItemTwo","price": 890,"count": 211,"date": "2013-11-02 16:53:19"}
]},
{"id": 2, "location": "DemoLocationTwo", "items":[
{"_id": 3,"name": "DemoItemThree","price": 9990,"count": 10,"date": "2013-11-02 19:12:40"},
{"_id": 4,"name": "DemoItemFour","price": 2500,"count": 20,"date": "2013-11-02 19:12:42"}
]}
]},
{"id": 2,"name": "DemoCompanyTwo", "fields":[
{"id": 3, "location": "DemoLocationThree", "items":[
{"_id": 5,"name": "DemoItemFive","price": 79000,"count": 11,"date": "2013-11-02 16:56:13"},
{"_id": 6,"name": "DemoItemSix","price": 649,"count": 8760,"date": "2013-11-02 16:56:13"},
{"_id": 7,"name": "DemoItemSeven","price": 149,"count": 4320,"date": "2013-11-02 16:57:19"}
]}
]}
]
我在 Mongoose 中制定了方案,如下:
var Schema = mongoose.Schema, ObjectId = Schema.ObjectId
var Items = new Schema({
_id: ObjectId,
name: String,
price: Number,
count: Number,
date: { type: Date, default: Date.now }
});
var Field = new Schema({
id: Number,
location: String,
items: [Items]
});
var Company = new Schema({
id: Number,
name: String,
Fields: [Field]
});
var cmp = mongoose.model('company', Company, "company");
var flds = mongoose.model('fields', Field, "fields");
var itm = mongoose.model('items', Items, "items");
请注意,Mongo 中项目的 _id 已更改为 ObjectId,因为我希望这能帮助我更好地处理这些嵌入式集合 - 但事实并非如此。
我想将项目插入到指定位置,或增加所选项目的计数,或删除所选项目。
company_id 和 field_id 包含在 URL 中,如下所示:
app.post('/:company_id/:field_id', function(req, res) { ... })
在此处理程序中,我将请求分开,例如:
app.post('/:company_id/:field_id', function(req, res) {
var company = req.params.company_id;
var field = req.params.field_id;
if (req.body.new != null)
{
cmp.findOne({}).where('id').equals(company).where('fields.id').equals(field).exec(function(err, comps) {
if (comps == null)
{ res.render('error', {title: 'Error!', msg: 'No such field!'}); }
else
{
i=0;
while (i < comps.fields.length && comps.fields[i].id != field)
{ i++; }
var r = new itm({"_id": "", "name": req.body.name, "price":req.body.price, "count":req.body.count});
comps.fields[i].items.push(r);
comps.save();
}
});
}
else if (req.body.mod != null)
{
//...
}
else if (req.body.del != null)
{
//...
}
res.redirect('/'+company+'/'+field);
})
如您所见,在添加项目时,我使用线性搜索来查找字段,我可以在其中推送新制作的项目...这非常非常难看,我确信一定有更简单的方法来做到这一点...
那么,增量或删除又如何呢?我不想以同样的方式...
第四个问题:您对 ID 有何看法?如何实现它们?我应该在任何地方使用 ObjectId,还是根本没有必要?
感谢任何帮助和想法!
最佳答案
我的愿景是,如果嵌入式文档几乎是静态的,则可以使用它们。您的对象对我来说看起来是动态的,所以我建议您尝试使用文档引用:
var Schema = mongoose.Schema, ObjectId = Schema.ObjectId
var Items = new Schema({
_id: ObjectId,
name: String,
price: Number,
count: Number,
date: { type: Date, default: Date.now }
field: {type: Schema.Types.ObjectId, ref: 'Field'}
});
var Field = new Schema({
id: Number,
location: String,
company: {type: Schema.Types.ObjectId, ref: 'Company'}
items: [{type: Schema.Types.ObjectId, ref: 'Items'}]
});
var Company = new Schema({
id: Number,
name: String,
fields: [{type: Schema.Types.ObjectId, ref: 'Field'}]
});
因此,您可以像 MySQL 中一样保留父引用 + 将子引用保留为数组以快速填充。因此,您不必搞乱嵌套文档:
Field.findOne({_id: fieldid}).exec(function(err, field){...do whatever you need...})
此外,我不建议将您的模型称为“Items”。用单数来调用它,例如“Item”。
关于node.js - 使用 Mongoose 从 Node 的 MongoDB 中的复杂嵌入式集合中插入、更新和删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20096030/
当我保存4条记录时,我需要将它们一一保存,所以我的代码是 a.save(function(){ b.save(function(){ c.save(function(){ d.save(f
Mongoose在版本4.2.7中创建了一个新的单个子文档功能(documentation和feature request),允许使用单个嵌入式子文档架构,其行为方式与一对多子文档的行为相同。 在父级
Mongoose 版本 >= 4.0 有一个时间戳选项,当 timestamps 设置为 时,该选项会为架构创建 updatedAt 和 createdAt 字段正确。 http://mongoose
我注意到某些图书馆喜欢 mock 鹅 ( https://github.com/mccormicka/Mockgoose/blob/master/test/index.spec.js ) 使用 req
我正在与 Mongoose 合作。我见过很多开发者发出以下命令: mongoose.Promise = global.Promise; 然后我很好奇 mongoose.Promise 的原始值是什么。
当我运行与数据库大量连接和断开连接的测试时,我收到以下警告。 (node) warning: possible EventEmitter memory leak detected. 11 connec
我可以在 Mongoose 的子文档数组中填充动态引用(使用“refPath”)虚拟字段吗? 数据结构如下 Group - Members -> User 代码:模型/模式 let MemberSc
我正在我的应用程序中做一些测试,看看内存缓存是否真的在工作。但是,由于 memory-cache 显然没有公开“命中”事件,我无法判断是否真的从缓存中获取数据。所以我试着看看当应用程序实际从数据库中获
我是 nestjs 的新手。我使用 @nestjs/mongoose,我需要在我的类模式中引用嵌套对象中的几个字段,但我不知道该怎么做。 dietDays 对象必须包含一个日期字段和包含对 Meal
我是 mongodb 的新手,我有一个这样的数据模型 { last_updated: Date.now(), csgo_items:[ {name: 'name', p
这是我的方案: var documentSchema = mongoose.Schema({ 'facts': [{ 'type': { type: String, requi
我想删除多个 _ids = ['123', '234', '345']; _ids.forEach(_id => { await model.deleteOne({ _id }); }); 有没有
我有一个像这样的 Mongoose 模式: var Address = { doorNo:String, city:String, state:String, coun
我的文档包含一个名为 clients 的字段那应该包含一组客户端ID。 { "first_name":"Nick", "last_name":"Parsons", "email":"nic
我遇到了以下我无法理解的代码行,尽管有很多教程提供了与 populate 的示例相关的信息。但没有一个能解释它究竟意味着什么。这是一个例子 var mongoose = require('mongoo
我有一个具有多个唯一性的架构,如下所示: var userSchema = new mongoose.Schema({ user: { type: String, unique:
我有一个 Mongoose 模式,其中有 4 个子模式。我一直在关注这里的文档https://github.com/LearnBoost/mongoose关于嵌入文档 var scenarios =
我希望每个字符串属性都默认设置为 true。有办法吗? ?? mongoose.Schema.String -> default { trim: true } var schema = new Sch
我有这个代码 var ClientSchema = new Schema({ name: {type: String, required: true, trim: true} }); var Cl
许多教程告诉您在您的 userSchema 页面中使用 bycrypt。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!