標籤:style http io ar java for sp strong 檔案
原文轉自:http://www.html5cn.org/article-7091-1.html
LokiJS一個輕量級的面向文檔的資料庫,由JavaScript實現,效能高於一切。目的是把JavaScript對象作為文檔,然後再進行儲存,並且以同樣的方式來檢索資料。 LokiJS可以運行於Node.js和所有支援JavaScript的瀏覽器、行動裝置 App程式上。
LokiJS支援欄位索引來實現更快的檔案訪問,效能也相當好(近50萬OPS/ s)。其內建的DynamicView類也能用於資料子集的索引,達到更快的效能。 LokiJS支援集合,很像MongoDB,並將資料以JSON格式儲存到硬碟上(根據會話來恢複狀態),所以你的資料是可移植的。
採用LokiJS的最理想情景:
- 行動裝置 App程式——尤其是基於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
【轉】LokiJS:純JavaScript實現的輕量級資料庫