我在 mongo 中有这个文件:
{
"_id": ObjectId("4d0b9c7a8b012fe287547157"),
"done_by": ["1"]
}
我想为“done_by”字段添加另一个值,所以我预期的文档将是::
{
"_id": ObjectId("4d0b9c7a8b012fe287547157"),
"done_by": ["1","2","3"]
}
我试试这个:
$conn = new Mongo();
$q = $conn->server->gameQueue;
$id = new MongoId("4d0b9c7a8b012fe287547157");
$q->update(array("_id"=>$id),array('$push' => array("done_by","2")));
但是没有任何反应,有人知道怎么做吗?
最佳答案
因为这些答案都没有真正告诉你这里出了什么问题......
$conn = new Mongo();
$q = $conn->server->gameQueue;
$id = new MongoId("4d0b9c7a8b012fe287547157");
$q->update(array("_id"=>$id),array('$push' => array("done_by","2")));
您的 $push 语句有问题,您没有推送值为“2”的“done_by”,您实际上是在发送“done_by”和“2"...
问题来了……
array('$push' => array("done_by","2"))
这应该有一个 => 而不是 ,
array('$push' => array("done_by" => "2"))
但是,请注意,每次运行此命令时,如果您希望 MongoDB 仅插入“2”(如果它在“done_by”中尚不存在),则它会插入另一个“2”,那么您应该使用 $addToSet ...
array('$addToSet' => array("done_by" => "2"))
这个语句不会每次都加2,只会第一次。
关于php - 将新值推送到 mongodb 内部数组 - mongodb/php,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4638368/