最近寫程式node.js程式的時候需要用到資料存放區,node.js可以使用的資料庫中的很多,mongodb、MySQL等等,但是我還是覺得這些資料庫太大了,大材小用,更主要的是麻煩。於是我找到了node-tiny,一個非關係型的資料庫,有點類似於mongodb。
tiny的文檔中講述了這樣一個事實,當我們在資料庫中搜尋資料的時候我們會根據id、名字、類別、標籤、日期等這些內容簡短的屬性來搜尋,極少的時候根據全文資訊等這樣的超長的欄位來搜尋。所以在建立一個tiny資料庫的時候tiny會將小於128位元組的屬性載入到記憶體中,這樣檢索速度會非常快,當檢索結束時tiny根據檢索的結果載入對於記錄超過128位元組的欄位。
使用方法:
1、安裝 npm install tiny
2、建立資料庫執行個體。
var Tiny = require('tiny');
Tiny('articles.tiny', function(err, db) {
// 使用資料庫執行個體db來操作資料。
});
說明:第一參數為儲存資料使用的檔案名稱,該檔案會在第一次使用時建立。第二參數為資料庫建立成功後執行的回呼函數。
3、使用例子。
Tiny('articles.tiny', function(err, db) {
db.set('doc001', {
title: 'the title',
content: 'the content'
}, function(err) {
console.log(err)
console.log('set!');
});
});說明:儲存文檔對象。第一參數為儲存資料的key,第二參數為要儲存的內容,第三參數為回呼函數。
4、函數大全:
set:增加記錄,參數如上。
remove:刪除記錄,參數同set。
update:更新記錄,第一參數同set(儲存的key),第二參數為回呼函數。
get:擷取一條記錄,第一參數同set,第二參數為回呼函數。
all:擷取所有資料,參數為回呼函數,不過該函數已經被棄用了。
each:迭代資料庫中的每一個對象。第一參數為迭代的函數(第一參數為記錄對象,第二參數為記錄的key);第二參數為迭代結束後的回呼函數;第三參數為一個布爾值,若為true則會將大於128位元組的也載入到記憶體迭代,預設false,建議保持預設。
fetch:檢索資料,第一參數為約束對象,第二三參數為函數,前者用於篩選資料,後者為檢索結束後的回呼函數。
find:mongodb風格的檢索。
close:關閉資料庫,關閉開啟的檔案。
kill:刪除所有資料。
compact:清理資料庫檔案中無用的資料。
5、補充,對於tiny來說增刪改都是向檔案中寫資料,注意是直接追加到檔案末尾,所以update方法和remove方法只是在檔案的末尾追加內容。之所以可以這樣設計是因為JavaScript對象屬性是唯一的,賦值操作會覆蓋掉之前的值,所以tiny只需按照檔案的順序解析檔案即可得到正確的資料。這樣設計的弊端是刪除掉的資料還會佔用儲存空間,compact方法就是將多餘的資料在檔案中刪除的方法。
6、各方法使用示範。
Tiny('articles.tiny', function(err, db) {
/*
for(var i = 0; i < 10; i++){
db.set('doc' + i, {
title: 'a document ' + i,
content: 'hello world ' + i
}, function(err) {
if(err){
console.log(err);
}else{
console.log('set!');
}
});
}
*/
/*
db.get("doc0", function(err, data){
console.log(arguments)
});
*/
/*
db.each(function(obj, key){
console.log(arguments);
}, function(){
}, false);
*/
/*
db.fetch({
limit: 3
}, function(obj, key){
return true;
}, function(err, datas){
console.log(arguments)
});*/
/*
db.compact(function(err) {
console.log('done');
});
*/
});