如果mongo db中存在/不存在字段,如何向对象添加数组数据

问题描述 投票:0回答:1

这是我的预期结果:

 "ForgotPassword": [
     {
       "UpdatedOn": ISODate("2017-12-06T11:23:23.0Z"),
    },
     {
       "UpdatedOn": ISODate("2017-12-06T11:45:13.0Z"),
    }
  ]

这就是我得到的:

"ForgotPassword": {
     "UpdatedOn": [
       ISODate("2017-12-20T11:48:15.0Z"),
       ISODate("2017-12-20T11:48:30.0Z"),
       ISODate("2017-12-21T11:57:21.0Z") 
    ] 
  } 

实际上忘记密码字段将不会出现在集合文档中。

当我第一次添加时,它应该创建Forgotpassword字段,并且在updatedon中应该存储

当我第二次在Forgotpassword里面添加时,updatedon应该重复一遍,它会存储在updateon中

这是我的查询:

 $updateQuery  =   $queryUpdate->update(

 array("CollaboratorId"=>(int)$collaboratorId), //query condition

 array('$addToSet'=>array('ForgotPassword.UpdatedOn'=>$currentDate)),

 array('upsert'=>1)

 );
mongodb multidimensional-array nosql insert-update findandmodify
1个回答
0
投票
$queryUpdate->findAndModify( 
array("CollaboratorId"=> (int)$collaboratorId),
array('$addToSet'=> array('ForgotPassword' =>array("UpdatedOn" => $currentDate))),
array('new' => 1,"upsert"=>1)
);

使用upsert和new以及findandmodify和addtoset它正在工作

© www.soinside.com 2019 - 2024. All rights reserved.