MongoDB更新GridFS记录
问题描述:
我已经实施CRUD
操作使用PHP + MongoDB
。以下代码用于使用GridFS
上传任何文件。MongoDB更新GridFS记录
$conn = new MongoClient();
$db = $conn->selectDB('mydb');
$gridfs = $db->getGridFS('uploads');
foreach ($_FILES as $file) {
if(in_array($file['type'], $acceptedTypes)){
$id = $gridfs->storeFile($file['tmp_name'], array('filename' => $file['name'], 'type' => $file['type'], "id"=> 13, "parentId" => "10", "title" => $file['name'], "isFolder" => 0));
}else{
echo 'file is not of correct type';
}
}
$conn->close();`
我可以上传使用上面的代码中的任何文件,但是当我尝试更新的任何文件的title
它只是不工作。更新文件名的代码如下。
$files = $db->fs->uploads;
$primId = $_GET['id_value'];
$renameTitle = $_GET['name'];
$updateData = array("title" => $renameTitle, "updatedDate" => date('Y-m-d'));
$files->update(array("id" => $primId), array('$set' => $updateData));
$conn->close();
这将更新其ID
传递的任何文件的title
。如果我需要更新任何记录,但是它不适用于任何GridFS
文件上载,则该代码可用。
更准确地说如果我通过ID
像下面,
$file = $gridfs->findOne(array('id' => 13)); **//WORKS**
$file = $gridfs->findOne(array('id' => $_GET['id'])); **//DO NOT WORKS**
有以更新GridFS
记录,可使用任何其它方法?
谢谢。
答
终于搞明白了。
MongoDB需要integer
变量来创建正确的查询。
如果您直接使用$_GET
或$_POST
值,则应先将其转换为整数值。在我的项目中,它的工作原理是这样的:
$id = (int)$_GET["id"];
$file = $gridfs->findOne(array('id' => $id)); **//WORKS LIKE CHARM**
希望它有助于某人。