php - mongodb-php 更新 $pull

标签 php mongodb pull

有一个集合“emailDeliveryActive”:

{
 "_id": ObjectId("4f1950f0e902edfc3e000001"),
 "coupons": {
   "4f1950b7e902edf23e000001": {
     "_id": ObjectId("4f1950b7e902edf23e000001"),
     "couponID": ObjectId("4f15c7d8e902edb667000000")
   },
   "4f1950bfe902ed843f000000": {
     "_id": ObjectId("4f1950bfe902ed843f000000"),
     "couponID": ObjectId("4f171f33e902ed4f4f000002")
   }
 },
 "recipients": [
   {
     "email": "test1@gmail.com",
     "get": "?auth=ZG1pdHJ5LnZvbG9zbmloaW5AZ21haWwuY29tfDA5OGY2YmNkNDYyMWQzNzNjYWRlNGU4MzI2MjdiNGY2"
   },
   {
     "email": "test2@gmail.com",
     "get": "?auth=ZGpyb3VibGVAZ21haWwuY29tfDA5OGY2YmNkNDYyMWQzNzNjYWRlNGU4MzI2MjdiNGY2"
   },
   {
     "email": "test3@gmail.com",
     "get": "?auth=a2FsaWJyb3YxQGdtYWlsLmNvbXwwOThmNmJjZDQ2MjFkMzczY2FkZTRlODMyNjI3YjRmNg=="
   }
 ],
 "title": "test"
}

必须来自一组“收件人”才能从给定电子邮件中删除项目。 这样做:

$result = $mongoDB->emailDeliveryActive->update(
array('_id' => $emailDelivery['_id']),
array(
'$pull'=>array(
'recipients.$.email' => 'test1@gmail.com'
)
)
);

$result 为 TRUE,但集合不变。我做错了什么?

最佳答案

您不需要 $ 运算符 - 它用于“查询中匹配数组项的位置” - 在这里使用没有意义。尝试:

 $result = $mongoDB->emailDeliveryActive->update(
     array('_id' => $emailDelivery['_id']),
     array(
          '$pull'=> array('recipients' => array('email' => 'test1@gmail.com'))
          )
 );

关于php - mongodb-php 更新 $pull,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8952714/

相关文章:

php - 调用 mysql_close() 的好处

php preg_match 日期格式 "yyyy-MM"

php - 在 CodeIgniter 中查找具有 varchar cols 日期的日期之间的项目

javascript - Stripe : Must provide source or customer

git - 有没有一种简单的方法可以知道哪些文件将在下一个 'git pull' 中更新?

php - MySQL查询没有结果,一分钟后有结果,记录看起来没有变化

java - 将实时数据记录到 NoSQL DB 的最佳实践

javascript - Mongoose - 删除子文档数组项

objective-c - 可拉 View Objective c

Git rebase 无参数版本与单参数版本