その発表の中でファイルDBである「NeDB」を知れたので試してみました。
基本的には以下のパワポの内容を実行しているだけです。
http://www.slideshare.net/isamusuzuki54/loop-backapiswift-46901252?next_slideshow=1
準備:
npm install nedb --save
※これだけ!
ソースコード:(今回は「nedb_test.js」というファイルで作成しています。)
var NeDB = require('nedb');
var db = {};
db.users = new NeDB({
filename: 'usersfile'
});
db.users.loadDatabase();
// insert
db.users.insert({name: 'hoge'});
db.users.insert({name: 'fuga'});
db.users.insert({name: 'uga'});
db.users.insert([
{name: 'foo'},
{name: 'bar'}
], function(err, newDoc){
console.log("[INSERT]");
console.log(newDoc);
});
// find
db.users.find({name: 'fuga'},
function(err, docs){
console.log("[FIND]");
console.log(docs);
});
db.users.find({name: /f*uga/},
function(err, docs){
console.log("[FIND F*]");
console.log(docs);
});
// remove
db.users.remove(
{name: 'fuga'},
{multi: true},
function (err, numRemoved){
console.log("[REMOVE]");
console.log(numRemoved);
});
db.users.remove(
{name: 'uga'},
{multi: true},
function (err, numRemoved){
console.log("[REMOVE]");
console.log(numRemoved);
});
実行結果:
%]node nedb_test.js
[INSERT]
[ { name: 'foo', _id: 'ShGylbRFFiR4nZcR' },
{ name: 'bar', _id: '7Kkhma6FdLUzQI7o' } ]
[FIND]
[ { name: 'fuga', _id: '8AKesKQfsnvVOdob' } ]
[FIND F*]
[ { name: 'fuga', _id: '8AKesKQfsnvVOdob' },
{ name: 'uga', _id: 'vbDsvmXtaB5xHNYo' } ]
[REMOVE]
1
[REMOVE]
1
実行後のファイル(usersfile)の内容:
{"name":"hoge","_id":"WuA7LFB50CWMnSX2"}
{"name":"fuga","_id":"8AKesKQfsnvVOdob"}
{"name":"uga","_id":"vbDsvmXtaB5xHNYo"}
{"name":"foo","_id":"ShGylbRFFiR4nZcR"}
{"name":"bar","_id":"7Kkhma6FdLUzQI7o"}
{"$$deleted":true,"_id":"8AKesKQfsnvVOdob"}
{"$$deleted":true,"_id":"vbDsvmXtaB5xHNYo"}
いやぁこんな簡単にDBを利用できるようになるなんてすばらしいですね!
利用できるAPIはMongoDBに準拠しているらしいので、
しっかりとしたDBに移行する際にも楽に対応できるかもしれないのがまた素敵ですね。
インストールするとついてくる次のマニュアルを見れば使い方も大体把握できると思います!
マニュアル:
node_modules/nedb/README.md