MongoDB:使用save()更新集合中的现有文档

时间:2011-01-01 12:35:17

标签: mongodb mongodb-php

大家。我喜欢漫画。现在我也在学习爱mongo: - )

how to use save() to update an existing document in a collection in MongoDB PHP的解释?但我无法将其应用于PHP的“现实”: - )

> var mongo = db.things.findOne({name:"mongo"});
> print(tojson(mongo));
{"_id" : "497dab624ee47b3a675d2d9c" , "name" : "mongo"}
> mongo.type = "database";
database
> db.things.save(mongo);
> db.things.findOne({name:"mongo"});
{"_id" : "497dab624ee47b3a675d2d9c" , "name" : "mongo" , "type" : "database"}

这是我的测试代码:

<?php
$a=array('_id'=>'test_a','field1'=>'anything');
$b=array('_id'=>'test_a','field2'=>'anything else');

$m=new Mongo();
$c=$m->db->test;
$c->save($a);
$c->save($b);//overwrites the previous record

/*
//With update() it works fine
$filter=array('_id'=>'test_a');
$update=array('$set'=>array('field2'=>'anything else'));
$c->update($filter,$update);
//$c->save($filter,$update);//Also tried...
*/

$f=$c->find();
echo $f->count()." found \n";
$i=iterator_to_array($f);//mongo cursos iterator
$m->close();//disconnect mongo

print_r($i);
?>

事实是,在PHP示例中,save()会覆盖该对象,而在JS示例中,它会更新它。我希望我可以像在JS中那样在PHP中重现。

提前致谢。

1 个答案:

答案 0 :(得分:12)

这些例子没有做同样的事情......

在JS示例中,您声明了对象 mongo

> var mongo = db.things.findOne({name:"mongo"});

然后,您修改了相同的对象以添加类型 ...

> mongo.type = "database";

在PHP示例中,您声明了两个对象......

$a=array('_id'=>'test_a','field1'=>'anything');
$b=array('_id'=>'test_a','field2'=>'anything else');

这就像在JS shell中执行以下操作...

> var apples = db.things.findOne({name:"mongo"});
> var orange = db.things.findOne({type:"database"});

所以 apples 是与 oranges 不同的对象/文档...因此当您运行 save()并传递NEW对象时完全覆盖了旧物体。

您的更新()工作正常,因为您搜索了该对象...

$filter=array('_id'=>'test_a');

然后在该对象上运行更新;传递新字段而不是传递新对象来替换它......

$update=array('$set'=>array('field2'=>'anything else'));
$c->update($filter,$update);

在JS示例中,您只有一个对象,因此它基本上将其附加到更新而不是替换它。

更正PHP代码

以下PHP将复制您在JS shell中所做的事情......

<?php

$connection = new Mongo();
$db = $connection->foo;
$collection = $db->testing;

// create new object & save
$a = array('color'=>'red');
$collection->save($a);

// add type = fruit to existing object & save
$a['type'] = 'fruit';
$collection->save($a);

// print out results.
echo "<pre>";
var_dump($collection->findOne(array("color" => "red")));
echo "</pre>";

?>

注意:我强烈建议您不要设置自己的对象 _id ,而是让驱动程序执行此操作就像我在上面的例子中所做的那样。