2012-10-06 14 views
10

何かが、私はNode.jsのためのデータベースのためのいくつかの研究を行ってきたとのMongoDBやCouchDBのようなほとんどの人が推奨しているのNoSQL型データベースは、ノードで使用します。NoSQLまたはSQLを使用したNode.JS?私はかなり理解していないよ

しかし、私はNoSQLのは、リレーショナルデータのためにその偉大ではないことがわかり...しかし、それは私が混乱してるところですさらに読み:ほとんどのビジネスアプリケーション(またはソーシャルネットワーキング型アプリケーション)は、リレーショナル・データを持っています。

たとえば、のは、私は、学生、教師、クラスがあり、学校のためのNode.jsでアプリケーションを構築していましょう。そこには多くの関係があることがわかります。 NoSQLの使用をお勧めしますか?

答えて

5

のMongoDBはしばしば彼らの共有非同期性の、およびためのJavaScript JSONの簡単な使用でのNode.jsとペアになっては、JSONベースのMongoDB文書構造を持つオブジェクト。つまり、特に複雑なレポートを行う必要がある場合、mongoDBには欠点があります。私が見つけたより良い説明の1つは、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" 
}) 
関連する問題