原文轉自:http://www.html5cn.org/article-7091-1.htmlphp
LokiJS一個輕量級的面向文檔的數據庫,由JavaScript實現,性能高於一切。目的是把JavaScript對象做爲文檔,而後再進行存儲,而且以一樣的方式來檢索數據。 LokiJS能夠運行於Node.js和全部支持JavaScript的瀏覽器、移動應用程序上。 html
LokiJS支持字段索引來實現更快的文件訪問,性能也至關好(近50萬OPS/ s)。其內置的DynamicView類也能用於數據子集的索引,達到更快的性能。 LokiJS支持集合,很像MongoDB,並將數據以JSON格式保存到硬盤上(根據會話來恢復狀態),因此你的數據是可移植的。
採用LokiJS的最理想情景:
- 移動應用程序——尤爲是基於HTML5的(例如:Cordova,Phonegap等等)
- 基於Node.js的小——中型應用程序的數據存儲
- 採用Node-Webkit的桌面應用程序
- LokiJS目前還處在alpha階段。源碼託管在Github上。
快速安裝:
[js]
- npm install lokijs
- or:
- bower install lokijs
複製代碼
建立一個數據庫:
- var db = new loki('loki.json')
- Pass the filename where to persist data
複製代碼
建立一個集合:
- var children = db.addCollection('children')
複製代碼
插入一個文檔:
- children.insert({name:'Sleipnir', legs: 8})
- children.insert({name:'Jormungandr', legs: 0})
- children.insert({name:'Hel', legs: 2})
複製代碼
檢索/獲取文檔:
- children.get(1); // returns Sleipnir
- children.find( {'name':'Sleipnir'} )
- children.find( { legs: { '$gt' : 2 } } )
複製代碼
建立一個動態視圖:
- var legs = children.addDynamicView('legs');
- legs.applyFind( { legs: { '$gt' : 2 } )
- legs.applySimpleSort('legs');
- legs.data();
複製代碼
MapReduce:
- children.mapReduce(
- function( obj ){ return obj.legs; } ,
- function( array ) {
- var sum = 0;
- for (var i=0; i < array.length; i++ ){
- sum += array[i];
- }
- return ( sum / array.length ).toFixed(2);
- });
複製代碼
LokiJS相關資料:
官網:http://lokijs.org/
託管地址:https://github.com/techfort/LokiJS
來源地址:http://www.csdn.net/article/2014-11-05/2822493-LokiJS?reload=1