javascript - 仅更新 Put Restify + SQLite3 上的某些字段

标签 javascript node.js rest sqlite restify

我正在使用Restify使用 SQLite3 数据库。到目前为止,这就是我的 put 方法:

server.put('/users/:userid', function(req, res, next) {
  bcrypt.hash(req.body.password, 10, function(err, hash) {
    if (err) {
      res.send(err);
    } else {
      db.run('UPDATE users SET username = ?, first_name = ?, last_name = ?, email = ?, password = ? WHERE id = ?', req.body.username, req.body.first_name, req.body.last_name, req.body.email, hash, req.params.userid, function(err) {
        if (err) {
          res.send(err);
        } else {
          res.json({ message:'Successfully updated user'});
        }
      });
    }
  });
  next();
});

为了使其工作,必须再次传入每个属性:

{
    "username": "greg",
    "first_name": "Greg",
    "last_name": "Davis",
    "email": "gdavis@email.com",
    "password": "password"
}

如果只需要更改电子邮件,显然这是多余的。我如何修改我的代码以便传递以下内容就足够了?

{
    "email": "gdavis@email.com",
}

我可以添加一些额外的逻辑来检查是否指定了新密码,因为这更复杂,但为每个字段添加逻辑似乎过多。

最佳答案

您可以考虑使用类似 Sequelize 的内容,而不是使用原始数据库查询。 ,与sqlite3兼容。然后,您可以检索用户对象,仅进行所需的更改,然后对该对象运行更新。

否则,看起来就像为每个可能的字段创建 if 语句一样。

关于javascript - 仅更新 Put Restify + SQLite3 上的某些字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41528831/

相关文章:

javascript - 如何在修改我的 View 后再次初始化 dragula

javascript - 对于 flowtype 是否有函数的 typeof

javascript - 对如何在node.js中实现异步回调感到困惑

javascript - node.js - 需要错误导致内存泄漏?

java - Unresolved 主机异常 Android

java - 如何使用@JsonIgnore仅在对象不是根对象时应用?

javascript - 有条件地改变 Angular 按钮中的链接

javascript - 每次在 ng-repeat 上添加一个内联值

node.js - 如何确定对象是否存在 AWS S3 Node.JS sdk

c# - 临时 block REST Controller