在非null约束下,node-sqlite插入失败,但是数据在那里?

时间:2019-04-06 00:05:16

标签: node.js sqlite express promise

我的nodejs应用程序中有以下代码,作为expressjs服务的一部分:

let db = sqlite.open(conf.database, { Promise }).then( (dba) => {
    P.all([dba.exec(accesslog_ddl),dba.exec(tokens_ddl)]).then(()=>{
        console.log("Database initialized ...");
    });
    return dba;
});

let upsertToken = function (token, expire, customer) {
    return db.then(d=>{
        console.log(`${token}, ${expire}, ${customer}`);
        return d.exec("insert into tokens (tokenid, name, email, cell, expire) values (?,?,'none','none','never')",
            [token,expire]);
    });
};

// ... expressjs setup ...

router.post('/tokens',(req,res) => {
    tokens.addToken(req.body.token, req.body.expires, req.body.name)
    .then(() => {res.status(201).send()})
    .catch((e) => {res.status(500).send(e)});
});

日志中的输出如下:

bluhbleh, never, fred flintstone
{ [Error: SQLITE_CONSTRAINT: NOT NULL constraint failed: tokens.name] errno: 19, code: 'SQLITE_CONSTRAINT' }
POST /services/tokens 500 20.287 ms - 2

这证明tokenexpirecustomerexec()调用之前都存在,但是由于NOT NULL约束失败,因此调用失败。 / p>

有关此代码的一些奇怪之处:<​​/ p>

  1. 我正在使用承诺的node-sqlite package
  2. 我正在使用约定的expressjs router
  3. 我真的对Promise(通常是Node.js)陌生,并且可能做的不正确。

我的完整代码在这里: https://bitbucket.org/highaltitudearchery/locker/src/master/

1 个答案:

答案 0 :(得分:2)

您使用的exec错误。 promisifiedDatabase#exec版本仅包含一个参数,即要执行的SQL。