shandy-dev / humus-doctrine-hydrator
Humus Doctrine (递归) 水化器
1.1.0
2013-07-07 11:33 UTC
Requires
- php: >=5.3.3
- doctrine/common: >2.2,<2.4-dev
- zendframework/zend-stdlib: >=2.2
Suggests
- doctrine/doctrine2: Doctrine 2 ORM
- doctrine/mongodb-odm: Doctrine MongoDB Object Document Mapper
This package is auto-updated.
Last update: 2024-08-26 00:50:21 UTC
README
Humus Doctrine 水化器
实现 Zend\Stdlib\Hydrator\HydratorInterface 的水化器,完全基于 Doctrine\Common
- 可以返回克隆的对象
- 允许您控制应提取哪些字段(递归地)
- 可以扁平化单个键
需求
安装
- 将
"prolic/humus-doctrine-hydrator": "dev-master"
添加到您的composer.json
- 运行
php composer.phar install
示例
假设您想将一个数组水化为一个对象,然后提取其所有内部字段
示例类:"User",与 "Locale"、"Language" 和 "Address" 有关系。地址实体也有关联到 "Country"。
$hydrator = new \Humus\Doctrine\Hydrator\Hydrator( $context->get('EntityManager'), // the entity manager true, // yes, we want a cloned object, not the original one array( 'id', 'name', 'firstname', 'fax', 'email', 'gender', 'locale' => array( 'name' ), 'preferred_contact_type' => array( 'id' ), 'address' => array( 'street', 'zip', 'city', 'country' => array( 'id', 'name' ), ), 'spoken_languages' => array( 'id', ), ), // we describe, what should be returned by extract, otherwise it could be that // a) We dump the Unit of Work // b) We dump half of the database false //do not flat single keys ); // we got some data $data = array( 'id' => 5, ); // we get the cloned address object, // just switch the clone argument in constructor to false, in order to get the real object back $address = $hydrator->hydrate($data, new \Application\Entity\Contact()); $result = $hydrator->extract($address); var_dump($result); // output: array(6) { ["id"]=> int(5) ["gender"]=> string(4) "male" ["name"]=> string(20) "Sascha-Oliver Prolic" ["locale"]=> array(1) { ["name"]=> string(10) "Deutsch DE" } ["address"]=> array(4) { ["street"]=> string(13) "Sample Street" ["zip"]=> string(5) "00000" ["city"]=> string(6) "Berlin" ["country"]=> array(2) { ["id"]=> int(1) ["name"]=> string(7) "Germany" } } ["spoken_languages"]=> array(1) { [0]=> array(1) { ["id"]=> int(1) } } } // Please note how the output changes (watch for locale) when you switch the "flatSingleKeys" flag to true // in the constructor of the hydrator