Sequelize - update record, and return result

后端 未结 7 848
粉色の甜心
粉色の甜心 2020-12-28 11:20

I am using sequelize with MySQL. For example if I do:

models.People.update({OwnerId: peopleInfo.newuser},
        {where: {id: peopleInfo.scenario.id}})
             


        
相关标签:
7条回答
  • 2020-12-28 11:54

    Here's what I think you're looking for.

    db.connections.update({
      user: data.username,
      chatroomID: data.chatroomID
    }, {
      where: { socketID: socket.id },
      returning: true,
      plain: true
    })
    .then(function (result) {
      console.log(result);   
      // result = [x] or [x, y]
      // [x] if you're not using Postgres
      // [x, y] if you are using Postgres
    });
    

    From Sequelize docs: The promise returns an array with one or two elements. The first element x is always the number of affected rows, while the second element y is the actual affected rows (only supported in postgres with options.returning set to true.)

    Assuming you are using Postgres, you can access the updated object with result[1].dataValues.

    You must set returning: true option to tell Sequelize to return the object. And plain: true is just to return the object itself and not the other messy meta data that might not be useful.

    0 讨论(0)
  • 2020-12-28 12:02

    There is another way - use findByPk static method and update not-static method together. For example:

    let person = await models.People.findByPk(peopleInfo.scenario.id);
    if (!person) {
      // Here you can handle the case when a person is not found
      // For example, I return a "Not Found" message and a 404 status code
    }
    person = await person.update({ OwnerId: peopleInfo.newuser });
    response(person).code(200);
    

    Note this code must be inside an asynchronous function.

    0 讨论(0)
  • 2020-12-28 12:06

    Update function of sequelize returns a number of affected rows (first parameter of result array).

    You should call find to get updated row

    models.People.update({OwnerId: peopleInfo.newuser},
        {where: {id: peopleInfo.scenario.id}})
        .then(() => {return models.People.findById(peopleInfo.scenario.id)})
        .then((user) => response(user).code(200))
        .catch((err) => {
             request.server.log(['error'], err.stack);
          });
    
    0 讨论(0)
  • 2020-12-28 12:07

    Finally i got it. returning true wont work in mysql , we have to use findByPk in order hope this code will help.

           return new Promise(function(resolve, reject) {
    User.update({
            subject: params.firstName, body: params.lastName, status: params.status
        },{
            returning:true,
            where: {id:id }                             
        }).then(function(){
            let response = User.findById(params.userId);                      
            resolve(response);
        }); 
    

    });

    0 讨论(0)
  • 2020-12-28 12:10

    You can just find the item and update its properties and then save it. The save() results in a UPDATE query to the db

    const job = await Job.findOne({where: {id, ownerId: req.user.id}});
    if (!job) {
        throw Error(`Job not updated. id: ${id}`);
    }
    
    job.name = input.name;
    job.payload = input.payload;
    await job.save();
    

    On Postgres:

    Executing (default): UPDATE "jobs" SET "payload"=$1,"updatedAt"=$2 WHERE "id" = $3
    
    0 讨论(0)
  • 2020-12-28 12:18

    same thing you can do with async-await, especially to avoid nested Promises You just need to create async function :)

    const asyncFunction = async function(req, res) {
        try {
            //update 
            const updatePeople = await models.People.update({OwnerId: peopleInfo.newuser},
                                        {where: {id: peopleInfo.scenario.id}})
            if (!updatePeople) throw ('Error while Updating');
            // fetch updated data
            const returnUpdatedPerson =  await models.People.findById(peopleInfo.scenario.id)
            if(!returnUpdatedPerson) throw ('Error while Fetching Data');
            res(user).code(200);
        } catch (error) {
            res.send(error)
        }
    } 
    
    0 讨论(0)
提交回复
热议问题