如何更新Sequelize Postgres中的数组

时间:2017-01-29 18:14:33

标签: node.js postgresql sequelize.js

我在Sequelize中有一个Postgres db的用户模型:

var User = sequelize.define('User', {
fb_id: DataTypes.STRING,
access_token: DataTypes.TEXT,
first_name: DataTypes.STRING,
last_name: DataTypes.STRING,
email: DataTypes.TEXT,
profilePictureURL: DataTypes.TEXT,
library: DataTypes.ARRAY(DataTypes.STRING)
}, {
underscored: true,
classMethods: {
  associate: function(models) {

   }
 }
  });

我正在尝试通过向数组中添加ISBN来更新库字段。这是我的POST请求的代码:

req.user.library.push(req.body._isbn); // adding the posted ISBN to the user object in my express-session

User.findOrCreate({where: {fb_id: req.user.fb_id}, 
        defaults: {
            access_token :      req.user.access_token,                 
            first_name :        req.user.first_name,
            last_name :         req.user.last_name,
            email :             req.user.email, 
            profilePictureURL : req.user.profilePictureURL,
            library: req.user.library // new library object
        }})
        .spread(function (updatedUser, created){
            res.status(200).json(updatedUser);
        }).error(function(err){
            res.status(500).json(err);
        });

没有错误,但在检查updatedUser对象后,库字段未更新。如何在Sequelize中正确更新数组字段?

2 个答案:

答案 0 :(得分:1)

我之前遇到过这个问题,并在他们的Github问题中找到了答案。我完成它的方式是

User.find({
  where: {
    fb_id: req.user.fb_id
  }
})
.then((user) => {
  user.library.push(req.body._isbn)
  user.update({
    library: user.library
  },{
    where: {
      fb_id: req.user.fb_id
    }
  })
  .then(user => res.json(user))
})

这绝对感觉有更好的方式,但这就是我找到方法的方式。

答案 1 :(得分:1)

对于下一个访客,我可能已经找到了解决此问题的更好方法:

User.update(
 {library: Sequelize.fn('array_append', Sequelize.col('library'), req.body._isbn)},
 {where: {fb_id: req.user.fb_id}}
);