一对多选择的项目

One to many selected items

我有 2 个实体:

团队(id,姓名,short_name...)
团队成员 (id, teams_id, player_id)

在管理员中,我有多选字段,并在提交时发送 ids 数组。如何将其保存在相关 table?

这是我在 TeamsController 中的部分代码

/**
 * @param array<string, mixed> $data
 */
protected function mapDataToEntity(array $data, Teams $entity): void
{
    $image = null;

    if ($imageId = ($data['logo']['id'] ?? null))
    {
        $image = $this->mediaRepository->findMediaById($imageId);
    }
    $entity->setLogo($image);
    $entity->setName($data['name']);
    $entity->setCountry($data['country']);
    $entity->setGender($data['gender']);
    $entity->setShortName($data['shortName']);
    $entity->setPlayers($data['players']); // <-- how do I handle THIS?
}

P.S。另外,我需要处理删除...

提前致谢...

您需要加载您需要的实体以将它们映射到您的实体。

你最好在这里看看 doctrine/orm 关于关联映射的文档:https://www.doctrine-project.org/projects/doctrine-orm/en/2.9/reference/association-mapping.html

您只需在加载图像时加载实体。 $entity->setPlayers($this->playerRepository->findById($data['players']));