Nodjs Sqllite3 не записывается на диск

У меня проблема с sqlite3 не записать на диск. Код, который я использую ниже. Мой общий список файлов превышает 470 КБ, и программа имеет тенденцию использовать несколько гигабайт памяти. во время работы программы test.db равен 0 байтам, а журнал не используется. Запись на диск начинается только тогда, когда db.close() бежит.

var fs = require('fs');
var sqlite3 = require('sqlite3').verbose();
var db = new sqlite3.Database('test.db');

db.serialize(function () {
    db.run("BEGIN;");
    db.run("CREATE TABLE if not exists Files (name TEXT);");
    db.run("COMMIT;");
    var files = fs.readdirSync("./files/");
    console.log("File list completed: " + files.length);
    for (var i = 0; i < files.length; i++) {
        db.run("INSERT INTO Files VALUES (?);",files[i]);
    }
});
db.close();

Я пытался удалить db.run("BEGIN;"); а также db.run("COMMIT;"); но это не помогает.

Ошибка?

Я сообщаю об этом как об ошибке на GitHub

1 ответ

Решение

Я думаю, что есть проблема с transaction а также db.serialize,
db.serialize это неуправляемый код. Я не знаю, когда это полезно.
Попробуйте поток управления, как показано ниже

var fs = require('fs');
var sqlite3 = require('sqlite3'); 
var async = require('async');

var db = new sqlite3.Database('test.db');

async.series ([
        function(cb) { 
            db.run('CREATE TABLE if not exists Files (name TEXT)', cb);
        },

        function(cb) { 
            db.run('begin transaction', cb); 
        },

        function(cb) {
            var files = fs.readdirSync("./files/");
            async.each(
                files, 
                function(file, cb) { db.run('INSERT INTO Files VALUES (?)', file, cb); }, 
                cb  
            );
        },

        function(cb) {
            db.run('commit transaction', cb);
        }
    ],
    function(err) {
        if (err) {
            console.log(err);
            db.run('rollback transaction'); // can fail if error occurs on create table
        }
        db.close();
    }
)

Если вам не нужно insert all rows or nothing что вы можете попробовать следующий код

var fs = require('fs');
var sqlite3 = require('sqlite3'); 
var async = require('async');

var db = new sqlite3.Database('test.db');

db.run('CREATE TABLE if not exists Files (name TEXT)', function (err) {
    if (err)
        return console.log(err);

    var files = fs.readdirSync("./files/");
    async.eachSeries(
        files, 
        function(file, cb) { db.run('INSERT INTO Files VALUES (?)', file, cb); }, 
        function(err) {
            console.log((err) ? err : 'Done');
            db.close();
        }  
    );
});
Другие вопросы по тегам