我有这个实体:
<?php
//namespace
//use ...
class Guide
{
private $id;
//private ...
//getters
//setters
}
?>
在控制器中,我使用实体管理器来检索该实体的数据。
$guides= $em->getRepository('AppBundle:Guide')
->findAll();
我的实体有4个参数:id,名称,页面,作者。 有没有办法添加两个额外的参数,它们不在类声明中,我也不想要在数据库中,如果实体管理器返回例如3行,我想o向每行添加两个额外的值并返回数据,例如添加两个布尔值:ok => true,警告=> false。
我已经尝试过了:
foreach($guides as $guide){
$guide->ok=true;
$guide->warning=false;
}
如果我转储$ guides,我会看到两个这样的参数:
-id:1
-name:'Guide 1'
-pages:12
-author:'John'
+"ok":true
+"warning":false
但是当我使用它发送响应时:
return new Response($serializer->serialize($guides, 'json'));
响应中没有两个额外的参数。
答案 0 :(得分:1)
您可以将属性添加到实体,而不必将其标记为ORM \ Column,例如:
<?php
//...
/**
* @ORM\Entity
* @ORM\Table(name="guides")
*/
class Guide
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
* @ORM\Column(name="title", type="string")
*/
private $name;
public $myAdditionalProperty;
//...
然后在您的控制器中进行设置:
foreach($guides as $guide){
$guide->myAdditionalProperty = "my amazing value";
}
然后,您可以序列化数据而无需在表中添加其他列