13

有些我不太了解,我一直在为 Node.JS 的数据库做一些研究,几乎每个人都推荐 NoSQL 类型的数据库,如 MongoDB 或 CouchDB 与 Node 一起使用。

但进一步阅读,我发现 NoSQL 对于关系数据并不是那么好……但这就是我感到困惑的地方:大多数业务应用程序(或社交网络类型的应用程序)都有关系数据。

例如,假设我正在使用 Node.JS 为一所拥有学生、教师和班级的学校构建一个应用程序。你可以看到那里有很多关系。你还会推荐使用 NoSQL 吗?

4

2 回答 2

5

MongoDB 通常与 Node.js 配对,因为它们具有共享的异步特性,并且因为 javascript JSON 对象与基于 JSON 的 mongoDB 文档结构很容易使用。也就是说,mongoDB 有其缺点,尤其是在必须完成复杂报告时。我发现的一个更好的解释是,在 mongo 中复制简单的数据访问需要在 mysql 中加入,但是如果你想以不同的方式加入数据,在 SQL 中会相当简单,但在蒙哥。

于 2012-10-06T01:57:40.497 回答
5

看看节点的猫鼬。它允许您为快速应用程序定义模型。您可以使用 .populate() 有效地加入 RDBMS 系统上的外键。

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

var mongoose = require('mongoose')
  , Schema = mongoose.Schema

var PersonSchema = new Schema({
  name    : String,
  age     : Number,
  stories : [{ type: Schema.Types.ObjectId, ref: 'Story' }]
});

var StorySchema = new Schema({
  _creator : { type: Schema.Types.ObjectId, ref: 'Person' },
  title    : String,
  fans     : [{ type: Schema.Types.ObjectId, ref: 'Person' }]
});

var Story  = mongoose.model('Story', StorySchema);
var Person = mongoose.model('Person', PersonSchema);

保存参考

将 refs 保存到其他文档的工作方式与通常保存 objectids 的方式相同,只需分配一个 ObjectId:

var aaron = new Person({ name: 'Aaron', age: 100 });

aaron.save(function (err) {
  if (err) return handleError(err);

  var story1 = new Story({
    title: "Once upon a timex.",
    _creator: aaron._id    // assign an ObjectId
  });

  story1.save(function (err) {
    if (err) return handleError(err);
    // thats it!
  });
})

人口

到目前为止,我们还没有做任何特别的事情。我们只是创建了一个 Person 和一个 Story。现在让我们看看填充我们故事的 _creator:

Story
.findOne({ title: /timex/ })
.populate('_creator')
.exec(function (err, story) {
  if (err) return handleError(err);
  console.log('The creator is %s', story._creator.name); // prints "The creator is Aaron"
})
于 2012-10-06T05:29:57.610 回答