带有NoSQL或SQL的Node.JS?

for*_*yez 11 sql nosql node.js

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

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

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

小智 5

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


cho*_*ovy 5

看一下mongoose节点.它允许您为快速应用程序定义模型.您可以使用.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);
Run Code Online (Sandbox Code Playgroud)

保存参考

将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!
  });
})
Run Code Online (Sandbox Code Playgroud)

人口

到目前为止,我们没有做任何特别的事.我们只是创造了一个人和一个故事.现在让我们来看看填充我们的故事的_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"
})
Run Code Online (Sandbox Code Playgroud)