1.首次使用时如何判断数据库是否为空?
有几种方法,比如db.iterator({ limit: 1 })
,db.createReadStream({ limit: 1 })
或只是检查磁盘上的目录是否存在(除非您level
在浏览器中使用)
2.[node.js使用leveldb(回调方式)](http://yijiebuyi.com/blog/1c7f6b3fe9aa6554a9a54ecd803e7d74.html)
注意:确保只有单进程调用leveldb(一次只能由一个进程打开),可将leveldb调用方法作为一个公共模块,如上面的方法。
async方法():
{valueEncoding: "json"}可以存取json数据
```
let level = require('level')
let path = require('path');
let defpath = path.join(__dirname);
let db = level(defpath + "/data", {valueEncoding: "json"})
async function put(key, value) {
let err = await db.put(key, value)
if (err) {
throw err
}
}
async function get(key) {
let err,value = await db.get(key)
if (err) {
throw err
}
return value
}
module.exports = {
put: put,
get: get,
db: db
}
```使用如:
let listOpt = {
time: time,
list: list
}
let err = await put("proxy", listOpt)
leveldb 5.0.1异常处理不支持异步方式,需要callback处理,或者说需要额外的异步处理方式。如
[为leveldb创建索引](https://www.tangshuang.net/4149.html)
db.get('name', function (err, value) {
if (err) return console.log('Ooops!', err) // likely the key was not found
// Ta da!
console.log('name=' + value)
})
或
db.get('foo', function (err, value) {
if (err) {
if (err.notFound) {
// handle a 'NotFoundError' here
return
}
// I/O or other error, pass it up the callback chain
return callback(err)
}
// .. handle `value` here
})