JavaScript实现的内存数据库LokiJS介绍和入门实例
作者:bea
LokiJS是一个内存数据库,将性能考虑放在第一位。 LokiJS支持索引和更快的文档访问,执行性能非常好(近50万OPS/秒)。其内置DynamicView类可以用于数据子集的索引,甚至获取更快的性能。 *阅读这篇文章来看一看LokiJS的性能表现。 LokiJS支持collections(数据集),跟MongoDB的很像,并且以JSON格式将数据保存到磁盘,所以你的数据是可移植的。 LokiJS即可运行在Node.js端和浏览器端。 JavaScript是一种简单易学,通
LokiJS是一个内存数据库,将性能考虑放在第一位。 LokiJS支持索引和更快的文档访问,执行性能非常好(近50万OPS/秒)。其内置DynamicView类可以用于数据子集的索引,甚至获取更快的性能。
*阅读这篇文章来看一看LokiJS的性能表现。
LokiJS支持collections(数据集),跟MongoDB的很像,并且以JSON格式将数据保存到磁盘,所以你的数据是可移植的。
LokiJS即可运行在Node.js端和浏览器端。
JavaScript是一种简单易学,通用的语言,所以在javascript数据库开发非常很容易且非常高效。如果你的MongoDB还没有退休,在下面这些情况,您可能会发现LokiJS是更理想的解决方案:
1.移动应用-特别是HTML应用。(Cordova, Phonegap) 2.Node.js内置的为小到中型应用设计的数据存储 3.内置在桌面中的应用(Node Webkit)
LokiJS正在支持独立服务器,可使用http/tcp客户端访问。
选择你最喜欢的范式
LokiJS的功能完全利用了JavaScript的力量。 如果函数式编程是您的首选风格,那么你肯定会喜欢使用视图来查询数据。 您也可以使用您偏爱的MongoDB的shell来查询文本对象。
快速入门
安装
LokiJS 可在npm和bower中安装. 运行:
代码如下:
npm install lokijs
或
代码如下:
bower install lokijs
使用
创建数据库:
代码如下:
var db = new loki('loki.json')
传入你需要保存数据的JSON文件
创建数据集:
代码如下:
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的性能表现。
LokiJS支持collections(数据集),跟MongoDB的很像,并且以JSON格式将数据保存到磁盘,所以你的数据是可移植的。
LokiJS即可运行在Node.js端和浏览器端。
JavaScript是一种简单易学,通用的语言,所以在javascript数据库开发非常很容易且非常高效。如果你的MongoDB还没有退休,在下面这些情况,您可能会发现LokiJS是更理想的解决方案:
1.移动应用-特别是HTML应用。(Cordova, Phonegap) 2.Node.js内置的为小到中型应用设计的数据存储 3.内置在桌面中的应用(Node Webkit)
LokiJS正在支持独立服务器,可使用http/tcp客户端访问。
选择你最喜欢的范式
LokiJS的功能完全利用了JavaScript的力量。 如果函数式编程是您的首选风格,那么你肯定会喜欢使用视图来查询数据。 您也可以使用您偏爱的MongoDB的shell来查询文本对象。
快速入门
安装
LokiJS 可在npm和bower中安装. 运行:
代码如下:
npm install lokijs
或
代码如下:
bower install lokijs
使用
创建数据库:
代码如下:
var db = new loki('loki.json')
传入你需要保存数据的JSON文件
创建数据集:
代码如下:
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);
});
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- jQuery中$.get、$.post、$.getJSON和$.ajax的用法详解
- 实现图片预加载的三大方法及优缺点分析
- jQuery Ajax()方法使用指南
- javascript匿名函数实例分析
- Linux下使用jq友好的打印JSON技巧分享
- 删除Javascript Object中间的key
- 如何在MVC应用程序中使用Jquery
- Jquery实现仿腾讯微博发表广播
- JavaScript数组常用操作技巧汇总
- jquery 实现返回顶部功能
- 超棒的响应式布局jQuery插件Freetile.js
- jQuery Masonry瀑布流插件使用详解
- javascript将url中的参数加密解密代码
- PHP使用方法重载实现动态创建属性的get和set方法
- JavaScript函数详解
- 提升PHP安全:8个必须修改的PHP默认配置
- 详解Javascript 装载和执行
- nodejs开发环境配置与使用
- jQuery带箭头提示框tooltips插件集锦