MongoGridFS::storeFile
(PECL mongo >=0.9.0)
MongoGridFS::storeFile — Сохраняет файл в базе данных
Описание
$filename
, array $metadata
= array()
, array $options
= array()
) : mixedСписок параметров
-
filename
-
Наименование файла или читаемого потока для хранения.
-
metadata
-
Другие поля метаданных для включения в файл документа.
Замечание:
Данные поля могут перезаписать поля, автоматически созданные драйвером, как указано в основной документации MongoDB » коллекции файлов. В качестве практического применения данного поведения можно указать собственный
chunkSize
или_id
для файла. -
options
-
Массив опций для операций вставки, выполняемых для коллекций
chunks
иfiles
. Смотрите MongoCollection::insert() для документации по этим параметрам.
Возвращаемые значения
Возвращает _id
сохраненного документа. Это будет сгенерированный MongoId, за исключением случая, когда _id
был явно указан в параметре metadata
.
Ошибки
Выдает исключение MongoGridFSException,
если при чтении filename
или вставке
в коллекции chunks
или files
возникает ошибка.
Примеры
Пример #1 MongoGridFS::storeFile() с дополнительными метаданными
<?php
$m = new MongoClient();
$gridfs = $m->selectDB('test')->getGridFS();
$id = $gridfs->storeFile('example.txt', array('contentType' => 'plain/text'));
$gridfsFile = $gridfs->get($id);
var_dump($gridfsFile->file);
?>
Результатом выполнения данного примера будет что-то подобное:
array(7) { ["_id"]=> object(MongoId)#6 (0) { } ["contentType"]=> string(10) "plain/text" ["filename"]=> string(11) "example.txt" ["uploadDate"]=> object(MongoDate)#7 (0) { } ["length"]=> int(26) ["chunkSize"]=> int(262144) ["md5"]=> string(32) "c3fcd3d76192e4007dfb496cca67e13b" }
Смотрите также
- MongoGridFS::put() - Сохраняет файл в базе данных
- MongoGridFS::storeBytes() - Сохраняет строку байтов в базе данных
- MongoGridFS::storeUpload() - Сохраняет загруженный файл в базе данных
- Основная документация MongoDB по » GridFS