Lowdb是轻量化的基于Node的JSON文件数据库。对于构建不依赖服务器的小型项目,使用LowDB存储和管理数据是非常不错的选择。

一:lowdb 使用及安装

在项目中的根目录安装 lowdb 命令如下:

npm install --save-dev lowdb

lowdb是基于lodash构建的,因此我们可以使用任何 lodash 强大的函数。并且我们可以串联使用。
下面我们的目录结构比如是如下:

|--- lowdb
| |--- node_modules
| |--- app.js
| |--- package.json

然后我们在app.js 添加如下代码:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json');
const db = low(adapter); db.defaults({posts: [], user: {}, count: 0 }).write();

如上保存后,我们在命令行中执行 node app.js 后,会在我们的项目中的根目录下新建一个叫 db.json 文件,该文件代码变成如下所示:

{
"posts": [],
"user": {},
"count": 0
}

如上代码,引入 lowdb包,然后引入 lowdb 中的适配器 FileSync。
lowdb自带的适配器有:FileSync、FileAsync 和 LocalBrowser。分别有以下可选参数:

defaultValue: 文件不存在时的默认值。
serialize/deserialize: 文件被写之前和读之后的操作。

比如如下代码:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 0 }).write();

如上代码,如果我们的db.json 没有数据的时候 才会重新调用 db.defaults初始化数据,否则的话会使用本地存储的数据。我们可以更改 count 的值试试看,不管我们在node命令行中运行多少次,值都是一样的,但是当我们把 db.json内容删除掉后,我们再运行下,发现最新的内容被写入进去了。

如上代码,如果我们把上面的代码改成这样的如下:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => console.log(data),
deserialize: (data) => console.log(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write();

那么在命令行中运行下,第一次被写入之前 serialize 打印 为 {} 空对象。然后就执行 db.defaults 操作就会把对应的数据写入到 db.json 文件中,然后我们就会执行 deserialize 操作对文件进行读取,然后在命令行中会打印 { posts: [], user: {}, count: 30 }。 打印完成后,我们没有做任何操作后,最后我们再来查看下 db.json文件的内容变成了 undefined. 因此我们可以判定 serialize 和 deserialize 这两个操作完成后,他们也会对文件进行写入操作。如果没有值被写入或操作的话,那么文件内容就变为undefined。当文件变为undefined后,我们再执行上面的代码,可以看到 db.defaults({posts: [], user: {}, count: 30 }).write(); 这句代码是不会被写入的。那么我们可以猜想的到,这句代码的含义是会判断该文件 有没有内容,如果没有内容的话文件数据才会被写入,否则的话就不会执行任何操作。我们可以再把 db.json 文件内容全部删除掉,我们再运行下 node app.js 命令后,可以看到这个时候 数据才会被写入进去。

1. 设置数据

我们可以对 db.json 数据里面设置某个字段的数据,比如如下代码:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write(); // 设置数据
db.set("user.name", 'kongzhi').write();

然后我们的 db.json 数据变成如下了:

{"posts":[],"user":{"name":"kongzhi"},"count":30}

2. 获取数据

我们可以对json文件获取某个字段后的值,然后进行添加数据操作,或者删除数据操作,总之我们可以操作数据,如下代码:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write(); // 设置数据
db.set("user.name", 'kongzhi').write(); // get 数据, 然后添加一条数据进去,最后写入文档里面去。
db.get('posts').push({'id': 1, 'title': 'welcome to hangzhou' }).write();

我们的db.json 文件代码变成如下所示:

{"posts":[{"id":1,"title":"welcome to hangzhou"}],"user":{"name":"kongzhi"},"count":30}

3. 更新数据,我们可以对某条数据进行更新。如下代码所示:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write(); // 设置数据
db.set("user.name", 'kongzhi').write(); // get 数据, 然后添加一条数据进去,最后写入文档里面去。
// db.get('posts').push({'id': 1, 'title': 'welcome to hangzhou' }).write(); // 使用 update 更新数据 这里的n 就是 count 的默认值,在db.json中的count默认值为30, 最后写入进去
db.update('count', n => n + 1).write();

运行后 db.json 数据代码如下所示:

{"posts":[{"id":1,"title":"welcome to hangzhou"}],"user":{"name":"kongzhi"},"count":31}

注意:由于我们的 lowdb 基于 lodash 的,因此我们可以使用 lodash 中的所有方法和属性。

4. find 查找字段中数据

我们可以对 db.json 中的某个字段的数据进行查找。代码如下所示:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write(); // 设置数据
db.set("user.name", 'kongzhi').write(); // get 数据, 然后添加一条数据进去,最后写入文档里面去。
// db.get('posts').push({'id': 1, 'title': 'welcome to hangzhou' }).write(); // 使用 update 更新数据 这里的n 就是 count 的默认值,在db.json中的count默认值为30, 最后写入进去
db.update('count', n => n + 1).write(); // 查找数据
const value = db.get('posts').find({'id': 1}).value();
console.log(value);

假如我们的db.json 代码如下:

{"posts":[{"id":1,"title":"welcome to hangzhou"}],"user":{"name":"kongzhi"},"count":33}

因此我们通过 db.get('posts').find({'id': 1}).value() 后就可以获取到值了,如下所示:

5. lowdb 的API

1. low(adapter): 它返回一个具有特定属性和功能的 lodash.
2. db.[...].write()/.value(): write() 方法是写入数据,value()方法是读取数据。
3. db.getState()/.setState(): 获取/设置数据库的状态。
4. db._ 数据库的lodash的实列。我们可以使用这个来添加我们自己的函数或者第三方的mixins。比如 lodash-id(https://github.com/typicode/lodash-id)

mixins 的使用列子如下:

代码如下:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write(); // 使用 mixin 混合模式来扩展我们自己的方法
db._.mixin({
getSecondData: function(arr) {
return arr[1];
}
});
// 调用 getSecondData 方法 获取到 posts 第二条数据
const xx = db.get('posts').getSecondData().value();
console.log(xx);

假如我们的db.json 代码如下数据:

{
"posts":[
{"id":1,"title":"welcome to hangzhou"},
{"id":2,"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

我们运行 node app.js 命令后,可以看到,我们可以获取到数组里面的第二条数据了,如下所示:

6. db.getState/db.setState 获取数据库状态/设置数据库的状态, 如下代码演示:

const low = require('lowdb');
const FileSync = require('lowdb/adapters/FileSync'); const adapter = new FileSync('./db.json', {
serialize: (data) => JSON.stringify(data),
deserialize: (data) => JSON.parse(data)
});
const db = low(adapter); db.defaults({posts: [], user: {}, count: 30 }).write(); // 获取数据库的状态
console.log(db.getState()); const newState = {}
db.setState(newState); console.log('-----------');
console.log(db.getState());

db.json 假如数据如下:

{
"posts":
[
{"id":1,"title":"welcome to hangzhou"},
{"id":2,"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

运行结果如下图所示:

7. 其他json数据操作

比如 db.json 数据如下所示:

{
"posts":
[
{"id":1,"title":"welcome to hangzhou"},
{"id":2,"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

1. 检查db.json中有没有 'posts' 这个字段是否存在。如下测试代码:

db.has('posts').value();  // 如果有该字段就会返回 true, 否则的话,返回false.

2. 设置值 set

db.set('posts', []).write(); // 运行完成后,就会对 posts 字段设置为 空数组了 [];

3. 获取特定字段的值

db.get('posts').map('id').value(); // 执行完成后会返回 [1, 2]

4. 获取数量

db.get('posts').size().value(); // 返回该数组的长度为 2

5. 获取特定信息的值

db.get('posts[0].id').value(); // 就会返回 1. 

6. 更新信息

db.get('posts')
.find({title: 'welcome to hangzhou'})
.assign({name: 'kongzhi'})
.write();

如上代码,我们可以看到,我们获取 posts这个字段,然后通过 find这个关键字去查找 {title: 'welcome to hangzhou'} 这样的,如果找到,就把 它改成 assign 里面的对象值。如果没有找到,就会在该对象里面添加该值,因此上面的结果返回如下:

{
"posts":[
{"id":1,"title":"welcome to hangzhou","name":"kongzhi"},
{"id":2,"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

如果我们把上面的语句改成如下语句,就会更改对应的值了:

db.get('posts')
.find({name: 'kongzhi'})
.assign({name: 'xxx'})
.write();

那么结果就变成如下:

{
"posts":[
{"id":1,"title":"welcome to hangzhou","name":"xxx"},
{"id":2,"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

7. 删除信息

db.get('posts')
.remove({name: 'xxx'})
.write();

那么结果就变为如下了:

{
"posts":[
{"id":2,"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

8. 移除属性

db.unset('posts[0].id').write();

那么结果变为如下了:

{"posts":[
{"title":"welcome to hangzhou"}
],
"user":{"name":"kongzhi"},
"count":33
}

9. 深拷贝

var xx = db.get('posts').cloneDeep().value();
console.log(xx); // 打印:[ { title: 'welcome to hangzhou' } ]

了解更多相关的知识,请看这里

学习Lowdb小型本地JSON数据库的更多相关文章

  1. 本地存储数据库indexedDB实现离线预览的功能

    今天在学习<高级JS编程>,看到离线存储,cookie和session都十分的熟悉,但是书中还提到了indexedDB和webSQL(已废弃),indexedDB可以像mysql一样建表, ...

  2. HTML5本地存储和本地的数据库

    一个网站如何能在客户的浏览器存储更多的数据呢? 在Html4的时代在浏览器端存储点网站个性化的数据,尤其是用户浏览器的痕迹,用户的相关数据等一般只能存储在Cookie中,但是大多是浏览器对于Cooki ...

  3. Xamarin android使用Sqlite做本地存储数据库

    android使用Sqlite做本地存储非常常见(打个比方就像是浏览器要做本地存储使用LocalStorage,貌似不是很恰当,大概就是这个意思). SQLite 是一个软件库,实现了自给自足的.无服 ...

  4. golang学习笔记16 beego orm 数据库操作

    golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...

  5. vue axios post不能本地json

    vue 脚本架里axios post是不能本地json,GET可以 解决这个问题需要自己在node里写脚本: 在build里新建立fakedata.js var express = require(' ...

  6. vue 模拟后台数据(加载本地json文件)调试

    首先创建一个本地json文件,放在项目中如下 { "runRedLight":{ "CurrentPage": 1, "TotalPages" ...

  7. 手把手教你vue配置请求本地json数据

    本篇文章主要介绍了vue配置请求本地json数据的方法,分享给大家,具体如下:在build文件夹下找到webpack.dev.conf.js文件,在const portfinder = require ...

  8. django学习-10.django连接mysql数据库和创建数据表

    1.django模型 Django对各种数据库提供了很好的支持,包括:PostgreSQL.MySQL.SQLite.Oracle. Django为这些数据库提供了统一的调用API. 我们可以根据自己 ...

  9. 访问本地json文件因跨域导致的问题

    我使用jquery的getJSON的方法获取本地的json文件,并进行操作,获取json 数据代码如下: $.getJSON("invite_panel.json",functio ...

随机推荐

  1. Oracle 开发使用笔记一

    1 前段时间换了新公司,工作一直很忙,没什么时间做总结! 关于几个知识点简单做下总结: 1绑定变量的使用: 1)使用几次,在后面的using中要声明几次,使用的顺序要对应声明的顺序 2 存储过程中执行 ...

  2. TestNG的静态方法mock的步骤

    最近团队内部对程序中使用大量的`静态方法`,而公司要求要有sonar扫描覆盖率的,因为在大量使用静态方法的地方若不mock,则覆盖率达不到.于是网上很少的文章讲解对静态方法的mock,大多都是如何使用 ...

  3. SVG波浪动画

    今天来试试用svg+css3制作波浪动画 下图是我制作出的效果 还不错吧 在制作波浪前,首先我们要画波浪啊,至于画波浪,如果你想直接通过计算贝塞尔曲线绘制出波浪... 好吧,那我也不拦着你 我就直接用 ...

  4. 个人永久性免费-Excel催化剂功能第88波-批量提取pdf文件信息(图片、表格、文本等)

    日常办公场合中,除了常规的Excel.Word.PPT等文档外,还有一个不可忽略的文件格式是pdf格式,而对于想从pdf文件中获取信息时,常规方法将变得非常痛苦和麻烦.此篇给大家送一pdf文件提取信息 ...

  5. Shiro在Web环境下集成Spring的大致工作流程

    1,Shiro提供了对Web环境的支持,其通过一个 ShiroFilter 入口来拦截需要安全控制的URL,然后进行相应的控制.      ①配置的 ShiroFilter 实现类为:org.spri ...

  6. python注释-输入输出-基本数据类型-运算符

    python注释 用处:注释用来书写一些解释性信息,对代码的逻辑作用等作出描述 单行注释.多行注释 # 这是行注释,注释内容与# 之间要空一格 print("hello world!&quo ...

  7. Linux卸载MySql——ubuntu版

    卸载mysql 1)删除mysql的数据文件 sudo rm /var/lib/mysql/ -R 2)删除mqsql的配置文件 sudo rm /etc/mysql/ -R 3)自动卸载mysql的 ...

  8. Pinyin4j简单使用教程

    Pinyin4j是一个流行的Java库,支持中文字符和拼音之间的转换,拼音输出格式可以定制,在项目中经常会遇到需求用户输入汉字后转换为拼音的场景,这时候Pinyin4j就可以派上用场 有自己私服的可以 ...

  9. 2019牛客暑期多校训练营(第三场)H题目

    题意:给你一个N×N的矩阵,求最大的子矩阵 满足子矩阵中最大值和最小值之差小于等于m. 思路:这题是求满足条件的最大子矩阵,毫无疑问要遍历所有矩阵,并判断矩阵是某满足这个条件,那么我们大致只要解决两个 ...

  10. 第二章 jQuery框架使用准备

    window常用属性: History:有关客户访问过的URL的信息 Location: 有关当前url的信息 常用方法: Confirm()将弹出一个确认对话框 open()在页面上弹出一个新的浏览 ...