加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 更新Mongo中的数组时出错

发布时间:2020-12-13 17:11:11 所属栏目:PHP教程 来源:网络整理
导读:我在我的mongo文档中创建了一个数组,所以看起来有点如下: { "_id" : ObjectId("4f59e19d0b7aab2903000004"),"details" : { x:1,y:2 }} 然后我尝试将新值推送到数组,执行: db.users.update({"_id" : ObjectId("4f59e19d0b7aab2903000004")},{$push: {"detai
我在我的mongo文档中创建了一个数组,所以看起来有点如下:

{ "_id" : ObjectId("4f59e19d0b7aab2903000004"),"details" : { x:1,y:2 }
}

然后我尝试将新值推送到数组,执行:

db.users.update({"_id" : ObjectId("4f59e19d0b7aab2903000004")},{$push: {"details": {"z":3}}});

但是我得到错误:

Cannot apply $push/$pushAll modifier to non-array

似乎我实际上能够将信息添加到数组的唯一方法是使用点符号来添加它,例如,

db.users.update({"_id" : ObjectId("4f59e19d0b7aab2903000004")},{"details.z": 3});

这似乎有效,但是当我有一个大约30个值的数组时,它似乎有点单调乏味.

为了清楚起见,我使用的是锂PHP框架,而不仅仅是手动输入,因此我可以遍历一个数组来预先添加’细节’.每个键,但我不认为这是必要的.有什么我不知道为什么它不会将值推入数组?

(我的锂代码如下:)

User::update(array('$push'=>array('details'=>array('z'=>3))),array('_id'=>$id))

谢谢,

解决方法

“details”是嵌入式文档,而不是数组.如果它是一个数组,它看起来像这样(注意[]表示一个数组):

{ "_id" : ObjectId("4f59f0531ae8f3b5f92246fe"),"details" : [ { "x" : 1 },{ "y" : 2 } ] }

如果你然后做$push:

db.users.update({"_id" : ObjectId("4f59f0531ae8f3b5f92246fe")},{$push : {"details": {"z":3}}})

你得到了预期的结果:

db.users.find({"_id" : ObjectId("4f59f0531ae8f3b5f92246fe")})

{ "_id" : ObjectId("4f59f0531ae8f3b5f92246fe"),{ "y" : 2 },{ "z" : 3 } ] }

基本上你试图推送到文档,而不是数组.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读