我是Symfony和Doctrine的新手。我有一些相关的不同实体,但是当我尝试在Fixtures中关联它们时,我得到一个例外:
关联字段“App \ Entity \ Make#$ type”的“App \ Entity \ VehicleType”类型的预期值,得到“Doctrine \ Common \ Collections \ ArrayColl” “而不是。
一旦我在第二个夹具中调用$ manager-> flush(),这似乎就会被抛出。我使用实体生成器来设置它们和关系。之后我将JoinColumn添加到ManyToOne注释中。这些关系设置如下:
class VehicleType
{
/**
* @ORM\OneToMany(targetEntity="App\Entity\Make", mappedBy="type")
*/
private $make;
public function __construct()
{
$this->make = new ArrayCollection();
}
}
class make
{
/**
* @ORM\ManyToOne(targetEntity="App\Entity\VehicleType", inversedBy="make")
* @ORM\JoinColumn(name="type", referencedColumnName="code")
*/
private $type;
public function __construct()
{
$this->type = new ArrayCollection();
}
}
固定装置看起来像这样:
class VehicleTypeFixtures extends Fixture
{
public function load(ObjectManager $manager)
{
$vehicleTypesData = AppFixtures::loadJSON('vehicle_types.json');
foreach($vehicleTypesData as $type) {
$vehicleType = new VehicleType();
$vehicleType->setCode($type->code);
$vehicleType->setDescription($type->description);
$manager->persist($vehicleType);
$this->addReference('type-'.$type->code, $vehicleType);
}
$manager->flush();
}
}
class MakeFixtures extends Fixture implements DependentFixtureInterface
{
public function load(ObjectManager $manager)
{
$makes = AppFixtures::loadJSON('makes.json');
foreach($makes as $make) {
$newMake = new Make();
$newMake->setCode($make->code);
$newMake->setDescription($make->description);
$type = (!empty($this->hasReference('type-'.$make->type)))
? $this->getReference('type-'.$make->type)
: false;
if ($type) {
$newMake->setType($type);
}
$manager->persist($newMake);
}
$manager->flush();
}
}
我在控制台中看到他们肯定以正确的顺序执行。显然我在构造函数中将$this->make
和$this->type
设置为new ArrayCollection()
s,但这是由实体生成器添加的,它看起来就像我想要的那样。
当我将get_class
转移到Make夹具中的$type
对象时,我发现它是一个Proxies\__CG__\App\Entity\Type
应该是正确的?
编辑:我的架构如下所示:
vehicle_type:
| code | varchar(10) | NO | PRI | NULL | |
| description | varchar(255) | NO | | NULL | |
make:
| code | varchar(10) | NO | PRI | NULL | |
| type | varchar(10) | YES | MUL | NULL | |
| description | varchar(255) | NO | | NULL | |
您的类VehicleType只需要一个Make,而不是Collection。您可以删除构造函数并确保仅提供单个实体,例如通过在setter方法中使用类型提示。
或者,您可能希望将两个类之间的关系更改为ManyToMany关系。