2012-10-06 29 views
10

东西我不是很了解,我一直在做一些研究,对数据库使用Node.js语言,几乎每个人都在推荐的NoSQL数据库类型的MongoDB一样CouchDB的或与节点使用。Node.JS与NoSQL或SQL?

但进一步的阅读中,我看到的NoSQL是不是关系数据,伟大的......但是这就是我越来越糊涂:大多数业务应用程序(或社交网络应用程序类型)有关系数据。

例如,假设我在建设一个的Node.js应用有学生,教师,班级的学校。你可以看到那里有很多关系。你还会推荐使用NoSQL吗?

回答

5

MongoDB是经常与Node.js的配对,因为它们共享异步性质,并且由于易采用javascript JSON的与所述基于JSON MongoDB的文档结构的对象。也就是说,mongoDB有它的缺点,特别是在复杂的报告必须完成时。我发现的一个更好的解释是,复制mongo中的简单数据访问需要在mysql中进行连接,但是如果您想要以不同的方式连接数据,那么在SQL中将非常简单,但是要复杂得多蒙戈。

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); 

节能裁判

保存裁判对其他文档的工作方式相同,您通常保存的ObjectID,只是分配的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! 
    }); 
}) 

人口

所以远远没有做任何特别的事情。我们只创建了一个人和一个故事。现在,让我们来看看填充我们的故事的_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" 
})