【轉】LokiJS:純JavaScript實現的輕量級數據庫

原文轉自: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]

  1. npm install lokijs
  2. or:
  3. bower install lokijs
複製代碼

建立一個數據庫:

  1. var db = new loki('loki.json') 
  2. Pass the filename where to persist data
複製代碼

建立一個集合:

  1. var children = db.addCollection('children')
複製代碼

插入一個文檔:

  1. children.insert({name:'Sleipnir', legs: 8})
  2. children.insert({name:'Jormungandr', legs: 0})
  3. children.insert({name:'Hel', legs: 2})
複製代碼

檢索/獲取文檔:

  1. children.get(1); // returns Sleipnir
  2. children.find( {'name':'Sleipnir'} )
  3. children.find( { legs: { '$gt' : 2 } } )
複製代碼

建立一個動態視圖:

  1. var legs = children.addDynamicView('legs');
  2. legs.applyFind( { legs: { '$gt' : 2 } )
  3. legs.applySimpleSort('legs');
  4. legs.data();
複製代碼

MapReduce:

  1. children.mapReduce( 
  2.   function( obj ){ return obj.legs; } , 
  3.   function( array ) { 
  4.     var sum = 0;
  5.     for (var i=0; i < array.length; i++ ){ 
  6.       sum += array[i];
  7.     }
  8.     return ( sum / array.length ).toFixed(2);
  9. });
複製代碼

LokiJS相關資料:

官網:http://lokijs.org/

託管地址:https://github.com/techfort/LokiJS

來源地址:http://www.csdn.net/article/2014-11-05/2822493-LokiJS?reload=1
相關文章
相關標籤/搜索