从其他表中排序MySQL更新值副本

时间:2019-01-05 02:57:09

标签: javascript mysql sequelize.js

我正在尝试制作一个控制器,该控制器将执行以下操作:

UPDATE bankapplication_accounts
SET last_successful_logged = last_present_logged
WHERE id = 1

我的续集中的控制器如下所示:

exports.updateLastLoggedDate = (req, res) => {
  User.findOne({
    where: {
      id: req.params.userId,
    },
  }).then(user => {
    if (user) {
      User.update(
        {
          last_successfull_logged: user.last_present_logged,
        },
        { where: { id: req.params.userId } },
      ).then(() => {
        res.status(200).send('logout correct');
      });
    }
  });
};

这个控制器能写得更好吗?

1 个答案:

答案 0 :(得分:0)

有2种方法

1:

exports.updateLastLoggedDate = (req, res) => {
User.findOne({
    where: {
      id: req.params.userId,
    },
  }).then((user) => {
    if (user) {
      user.update({
          last_successfull_logged: user.last_present_logged,
        }).then(() => {
        res.status(200).send("logout correct");
      });
    }
  });
};

2:

User.update(
    {
       last_successfull_logged: user.last_present_logged,
    }, /* set attributes' value */
    {
        where: {
             id: req.params.userId,
          },
     }, /* where criteria */
  ).then(() => {
    res.status(200).send("logout correct");
  });