Мне нужно создать главный объект с именем Users и еще один с именем Specialties. У пользователя может быть много специальностей.
Моя сущность пользователей :
<?php
namespace App\Entity;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Security\Core\User\AdvancedUserInterface;
use Symfony\Component\Security\Core\User\UserInterface;
use Symfony\Component\Serializer\Annotation\Groups;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;
/**
* @ORM\Entity(repositoryClass="App\Repository\UsersRepository")
* @UniqueEntity(
* fields={"email"},
* errorPath="email",
* message="It appears you have already registered with this email."
* )
*/
class Users implements UserInterface
{
/**
* Users constructor.
*/
public function __construct()
{
$this->created_at = new \DateTime();
$this->specialtyId = new ArrayCollection();
}
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
* @Groups({"public"})
*/
private $id;
//Other properties there...
/**
* @ORM\ManyToMany(targetEntity="App\Entity\Specialties", inversedBy="users")
*/
private $specialtyId;
public function getId(): ?int
{
return $this->id;
}
/**
* @return Collection|Specialties[]
*/
public function getSpecialtyId(): Collection
{
return $this->specialtyId;
}
public function addSpecialtyId(Specialties $specialtyId): self
{
if (!$this->specialtyId->contains($specialtyId)) {
$this->specialtyId[] = $specialtyId;
}
return $this;
}
public function removeSpecialtyId(Specialties $specialtyId): self
{
if ($this->specialtyId->contains($specialtyId)) {
$this->specialtyId->removeElement($specialtyId);
}
return $this;
}
}
Моя сущность сущность:
<?php
namespace App\Entity;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Entity(repositoryClass="App\Repository\SpecialtiesRepository")
*/
class Specialties
{
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
//Other properties there...
/**
* @ORM\ManyToMany(targetEntity="App\Entity\Users", mappedBy="specialtyId")
*/
private $users;
public function __construct()
{
$this->users = new ArrayCollection();
}
/**
* @return Collection|Users[]
*/
public function getUsers(): Collection
{
return $this->users;
}
public function addUser(Users $user): self
{
if (!$this->users->contains($user)) {
$this->users[] = $user;
$user->addSpecialtyId($this);
}
return $this;
}
public function removeUser(Users $user): self
{
if ($this->users->contains($user)) {
$this->users->removeElement($user);
$user->removeSpecialtyId($this);
}
return $this;
}
}
При попытке сохранить форму регистрации я получил следующее исключение:
**> Не удалось определить тип доступа для свойства "specialtyId" в классе
" App \ Entity \ Users ": свойство" specialtyId "в классе" App \ Entity \ Users "может быть определено с помощью методов" addSpecialtyId () "," removeSpecialtyId () ", но новое значение должно быть массивом или экземпляром \ Traversable, задано «App \ Entity \ Specialties». **
Создана новая таблица с именем: users_specialties, которая содержит: users_id / specialties_id