无法使用lokiJS将db保存为json文件

时间:2016-10-25 17:39:49

标签: javascript json database lokijs nosql

我正在浏览器中测试LokiJS。我想将创建为json文件的数据库保存在同一文件夹中。但没有任何反应。这是我在网上找到的代码,我正在测试:

var db = new loki('test.json');
var db2 = new loki('test.json');

var users = db.addCollection('users');
users.insert({
    name: 'joe'
});
users.insert({
    name: 'john'
});
users.insert({
    name: 'jack'
});
console.log(users.data);
db.saveDatabase();

db2.loadDatabase({}, function () {
    var users2 = db2.getCollection('users')
    console.log(users2.data);
});

我缺少什么?感谢。

1 个答案:

答案 0 :(得分:3)

是的,它有点棘手

您必须在使用数据库之前加载数据库,否则将使用空数据库进行擦除。这是一个小脚本,允许您加载集合或创建一个集合,如果它不存在+保存更改

var loki = require('lokijs'),
    db = new loki('test.json');

function loadCollection(colName, callback) {
    db.loadDatabase({}, function () {
        var _collection = db.getCollection(colName);

        if (!_collection) {
            console.log("Collection %s does not exit. Creating ...", colName);
            _collection = db.addCollection('users');
        }

        callback(_collection);
    });
}

loadCollection('users', function (users) {
    //show the users
    console.log(users.data);

    var newUser = {
        name: 'user_' + (new Date()).getTime()
    };

    //add one
    users.insert(newUser);

    console.log("Added a new user => ", newUser);

    //save 
    db.saveDatabase();
});