一对多选择的项目
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']));
我有 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']));