5

我正在使用MongoDBand GridFSin PHP,并试图弄清楚如何通过 _id.

这是我的代码:

 $ids = array("50401f40ff558cec38000061", "62401f40ff558cec38000072", "73401f40ff558cec38000083");
 $mongo_ids = array();
 foreach($ids as $id) {
    $mongo_ids[] = new MongoId($id);
 }

 $mongo_grid_fs->remove(array("_id" => $mongo_ids));

知道我做错了什么吗?

4

2 回答 2

3

由于 GridFS 的实际工作方式,这对于单个请求是不可能的。

你有两个集合:

  • 文件

为了删除 GridFs 文件,您必须同时查询这两个表。因此 remove() 函数实际上调用块集合,然后从文件集合中删除文件。

由于 MongoDB 从根本上说不能在一个请求中查询两个集合(基本上已加入删除),因此您必须为每个文件发送一个删除请求以删除,否则您将剩余的块占用您的块集合中的空间。

因此,考虑到这一点,@ToddMoses 的答案是正确的。

您当然可以使用:http ://www.php.net/manual/en/mongogridfs.remove.php但我相信它做的完全一样,只是抽象了,所以您的查询应该是:

$mongo_grid_fs->remove(array("_id" => array('$in' => $mongo_ids)));
于 2012-08-31T07:42:18.693 回答
2

首先,使用 MongoDB::lastError() 找出问题所在。MongoGridFS::remove 如果失败,不会向您显示消息。做这样的事情:

$errorArray = $db->lastError();
var_dump($errorArray);

看来问题是您没有正确设置标准。最简单的做法是使用 Delete 而不是 Remove,因为 Delete 将 ID 作为其唯一参数:

public bool MongoGridFS::delete ( mixed $id )

这会从数据库中删除文件,而 remove 会从集合中删除文件。由于无论如何您都在循环,您可以执行以下操作:

foreach($ids as $id) {
    $mongo_grid_fs->delete($id);
 }
于 2012-08-31T03:32:12.493 回答