2012-10-06 10 views
10

Coś, czego nie całkiem rozumiem, robiłem badania dla baz danych dla Node.JS i prawie wszyscy polecają bazy danych typu NoSQL, takie jak MongoDB lub CouchDB, do używania z Węzłem.Node.JS z NoSQL lub SQL?

Ale czytanie dalej Widzę, że NoSQL nie jest zbyt dobry dla danych relacyjnych ... Ale to jest miejsce, w którym wpadam w zakłopotanie: większość aplikacji biznesowych (lub aplikacje typu sieci społecznościowe) ma relacyjne dane.

Załóżmy na przykład, że tworzę aplikację w pliku Node.JS dla szkoły, w której uczniowie, nauczyciele, klasy. Widać tam wiele związków. Czy nadal zaleca się używanie NoSQL?

Odpowiedz

5

MongoDB jest często sparowany z Node.js z powodu ich współdzielonej asynchronicznej natury, a także z powodu łatwego korzystania z javascriptowych obiektów JSON ze strukturą dokumentu mongoDB opartą na JSON. Powiedział, że mongoDB ma swoje wady, szczególnie, gdy musi być złożona sprawozdawczość. Jednym z lepszych wyjaśnień, które znalazłem, jest to, że replikacja łatwego dostępu do danych w mongo wymagałaby sprzężenia w mysql, jednak gdybyś chciał dołączyć do danych w inny sposób, byłoby to raczej proste w SQL, ale o wiele bardziej skomplikowane w Mongo.

5

Spójrz na mangusta dla węzła. Pozwala na zdefiniowanie modeli dla aplikacji ekspresowej. Możesz użyć .populate(), aby skutecznie dołączyć do tego, co byłoby obcym kluczem w systemie 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); 

Zapisywanie bibl

Zapisywanie bibl do innych dokumentów działa w ten sam sposób, w jaki normalnie zapisać objectids, po prostu przypisać 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! 
    }); 
}) 

Population

Tak daleko nie zrobiliśmy nic specjalnego. Stworzyliśmy tylko Osobę i Historię. Teraz spójrzmy na zapełnianie naszego programu _creator: