更新始终插入最后一个数组值

时间:2018-04-11 06:04:41

标签: node.js express loopbackjs strongloop

我是节点新手并搜索了很多找到解决方案,但是如果有人可以帮我解决这个问题,那么我就不知道如何使用我的情况

Permissiontb.assembleAndInsert = async (ctx, cb) => {
for (let i = 0; i < ctx.req.body.view.length; i++) {
       console.log('outside i  '+i)
       await Process(ctx,i);
 }
};

 function  Process(ctx,i) {
let data={company_id:ctx.args.options.accessToken.userId,
       userid:ctx.req.body.userid,
       perpage:ctx.req.body.perpage[i].id,
       view:ctx.req.body.view[i],
       edit:ctx.req.body.edit[i],
       update:ctx.req.body.update[i],
       delete:ctx.req.body.delete[i]}

     console.log('inside '+i)
  return new Promise((resolve, reject) => {
    Permissiontb.find({where:{and: [{userid:ctx.req.body.userid}, {perpage:ctx.req.body.perpage[i].id}] }},function(err,result){
     if(err){
             var err = new Error('Some thing went wrong');
             err.statusCode = 444;
             console.log('err'+err)
             resolve(err)
     }else{ console.log(result.length)
         if(result.length>0){
           console.log(ctx.req.body.userid)  
           console.log('page id '+ctx.req.body.perpage[i].id)
           const pgid=ctx.req.body.perpage[i].id
           const vd=ctx.req.body.view[i]
           const ed=ctx.req.body.edit[i]
           const up=ctx.req.body.update[i]
           const del=ctx.req.body.delete[i]
            console.log(ctx.req.body.view[i])
            console.log(ctx.req.body.edit[i])
            console.log(ctx.req.body.update[i])
            console.log(ctx.req.body.delete[i])
            console.log('findinside update '+i)

              resolve(Permissiontb.update({where:{and: [{userid:ctx.req.body.userid}, {perpage:pgid}] }},{view:vd,edit:ed,update:up,delete:del}))

         }else{
             resolve(Permissiontb.create([data]))
         }

     }

    })

 })
}

现在问题是控制台登录if(result.lenght&gt; 0)条件如下: - console.log(ctx.req.body.view [i])正确值获取但是当update方法总是插入最后一个数组值时任何人都可以告诉我我做错了什么

1 个答案:

答案 0 :(得分:1)

最后我发现灵魂可能会帮助其他面临像我这样的问题

var async = require('async');
 module.exports = function(Permissiontb) {
Permissiontb.assembleAndInsert = async (ctx, cb) => {

for (let i = 0; i < ctx.req.body.view.length; i++) {
       await Process(ctx,i);
   }
 };
Permissiontb.remoteMethod('assembleAndInsert', {
    http: {
      path: '/assembleAndInsert',
      verb: 'post',
     },
accepts: [{ arg: 'data', type: 'object', http: { source: 'context' } },

{"arg": "options", "type": "object", "http": "optionsFromRequest"}],
returns: {
  arg: 'data',
  type: 'object',
},
});


function  Process(ctx,i) {
  let data={company_id:ctx.args.options.accessToken.userId,
            userid:ctx.req.body.userid,
            perpage:ctx.req.body.perpage[i].id,
            view:ctx.req.body.view[i],
             edit:ctx.req.body.edit[i],
             update:ctx.req.body.update[i],
            delete:ctx.req.body.delete[i]}
     return new Promise((resolve, reject) => {
 resolve(Permissiontb.upsertWithWhere({userid:ctx.req.body.userid,perpage:ctx.req.body.perpage[i].id},data))

  })
 }

问题是即时通讯使用Permissiontb.upsertWithWhere(//我使用where here-&gt; {userid:ctx.req.body.userid,perpage:ctx.req.body.perpage [i] .id},data) )