array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ru', ), 'this' => array ( 0 => 'class.mongodb-bson-persistable.php', 1 => 'MongoDB\\BSON\\Persistable', ), 'up' => array ( 0 => 'book.bson.php', 1 => 'MongoDB\\BSON', ), 'prev' => array ( 0 => 'class.mongodb-bson-type.php', 1 => 'MongoDB\\BSON\\Type', ), 'next' => array ( 0 => 'mongodb-bson-persistable.bsonserialize.php', 1 => 'MongoDB\\BSON\\Persistable::bsonSerialize', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ru', 'path' => 'reference/mongodb/bson/persistable.xml', ), 'extra_header_links' => array ( 'rel' => 'alternate', 'href' => '/manual/en/feeds/class.mongodb-bson-persistable.atom', 'type' => 'application/atom+xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(mongodb >=1.0.0)
Классы могут реализовывать этот интерфейс для использования преимуществ автоматического ODM (сопоставление документов объекта) поведения в драйвере. Во время сериализации драйвер вставляет свойство __pclass, содержащее имя класса PHP, в данные, возвращаемые MongoDB\BSON\Serializable::bsonSerialize(). Во время десериализации то же свойство __pclass будет использоваться для вывода класса PHP (независимого от любой конфигурации типа карты), которая должна быть создана до вызова MongoDB\BSON\Unserializable::bsonUnserialize(). Смотрите Постоянные данные для получения дополнительной информации.
Замечание: Даже если MongoDB\BSON\Serializable::bsonSerialize() вернёт последовательный массив, внедрение свойства __pclass приведёт к сериализации объекта, как документа BSON.