将 PersistentCollection 添加到 fixture 中的对象

Add PersistentCollection to an object in fixture

我正在尝试创建一个用于创建用户的新装置。

这是灯具:

class UserFixtures extends Fixture implements DependentFixtureInterface
{
    private ManagerRegistry $_managerRegistry;

    public function __construct(ManagerRegistry $managerRegistry)
    {
        $this->_managerRegistry = $managerRegistry;
    }

    public function load(ObjectManager $manager)
    {
        $groups = $manager->getRepository(Group::class)->findAll(); // This return an array of object. I want a PersistentCollection
        $company = $manager->getRepository(Company::class)->findOneBy(['company_name' => 'HANFF - Global Health Solution']);
        $user = new User();
        $user->setLogin("TEST_TEST")
             ->setName("TEST_Name")
             ->setFirstName("TEST_Firstname")
             ->setPassword("test")
             ->setEmail("TEST@hanff.lu");
        $user->setCompany($company);
        $user->setGroups($groups); // This don't work as it is just an array
        $manager->persist($user);
        $manager->flush();
    }

    /**
     * @inheritDoc
     */
    public function getDependencies()
    {
        return array(
                CompanyFixture::class,
                GroupFixture::class
        );
    }
}

所以我已经创建了公司和组,这些公司和组一直保存到我的数据库中。 现在我想为我的新用户设置以前坚持的公司和集团。

这是为我的公司工作的,因为这是一个单一的对象。 但这对我的组不起作用,因为它被键入为 PersistenCollection 对象和 getRepository(Group::class)->findAll() return 对象数组 Group.

此处数据包含在 $groups 变量中:

array:2 [
  0 => App\Entity\Group {#1039
    -code: "NAT"
    -label: "National"
  }
  1 => App\Entity\Group {#1044
    -code: "VET"
    -label: "Vétérinaire"
  }
]

这是我将组定义到我的用户实体中的方式:

Class User{
  //    ...
  /**
     * @var PersistentCollection
     * Many user has many groups
     * @ORM\ManyToMany(targetEntity="Group")
     * @ORM\JoinTable(name="user_group",
     *      joinColumns={@ORm\JoinColumn(name="user_id", referencedColumnName="id")},
     *      inverseJoinColumns={@ORM\JoinColumn(name="group_code", referencedColumnName="`code`")}
     *      )
     */
    private PersistentCollection $groups;

    public function getGroups(): PersistentCollection
    {
        return $this->groups;
    }

    public function setGroups(PersistentCollection $groups): self
    {
        $this->groups = $groups;
        return $this;
    }

    public function addGroup($group): self
    {
        $this->getGroups()->add($group);
        return $this;
    }
    
    //     ...
}

我在某处(不记得在哪里)读到过当你使用 doctrine 持久化一个对象时,它可以作为 PersistentCollection 访问,但我不知道该怎么做(除了通过创建一个新的 PersistentCollection() 这当然不是最好的方式)?

我尝试设置 ArrayCollection 而不是 PersistentCollection,但如果我这样做,当我尝试保留我的用户对象时,学说对我大喊大叫,因为它无法转换 ArrayCollectionPersistentCollection(我猜)。

您必须将属性、参数和 return 值的类型更改为 Doctrine\Common\Collections\Collection 接口。这是 ArrayCollectionPersistentCollection 共享的接口。不要忘记在构造函数中将 groups 属性 初始化为 ArrayCollection。否则对 addGroup 的调用将在新用户实体上失败。

class User
{
  //    ...
  /**
     * @ORM\ManyToMany(targetEntity="Group")
     * @ORM\JoinTable(name="user_group",
     *      joinColumns={@ORm\JoinColumn(name="user_id", referencedColumnName="id")},
     *      inverseJoinColumns={@ORM\JoinColumn(name="group_code", referencedColumnName="`code`")}
     *      )
     */
    private Collection $groups;

    public function __construct()
    {
        // other initialization
        $this->groups = new ArrayCollection();
    }

    public function getGroups(): Collection
    {
        return $this->groups;
    }

    public function setGroups(Collection $groups): self
    {
        $this->groups = $groups;
        return $this;
    }

    public function addGroup($group): self
    {
        $this->getGroups()->add($group);
        return $this;
    }
    
    //     ...
}