У меня есть таблица с именем 'student_assignment', в которой у меня есть несколько столбцов, из которых я показываю 2 из них ниже:
Оба эти столбца также являются внешними ключами.
StudentId assignmentId
10 7 -> allowed
10 8 -> allowed
11 7 -> allowed
11 7 -> not allowed, the combination of 11 7 already exists in table
Я пробовал это в моем файле сущности, но он не работает.
/**
* Webkul\CampusConnect\Entity\StudentAssignment
*
* @Table(name="student_assignment",
* uniqueConstraints={
* @UniqueConstraint(name="assignment_unique",
* columns={"student", "assignment"})
* }
* )
* @Entity
*/
Пожалуйста, как реализовать это с помощью ORM в Symfony 4.
У меня есть ссылка, которая делает то же самое, но в Mysql. Я хочу решение для Symfony ORM.
введите описание ссылки здесь
Ошибка:
[Семантическая ошибка] Аннотация "@Table" в классе
Webkul \ CampusConnect \ En tity \ StudentAssignment никогда не импортировался.
Возможно, вы забыли добавить для этого заявление "u se"
аннотаций
Организация:
namespace Webkul\CampusConnect\Entity;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\ORM\Mapping\Table;
/**
* Webkul\CampusConnect\Entity\StudentAssignment
*
* @ORM\Table(name="student_assignment",
* uniqueConstraints={
* @UniqueConstraint(name="assignment_unique",
* columns={"student", "assignment"})
* }
* )
* @Entity
*/
class StudentAssignment
{
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\ManyToOne(targetEntity="Webkul\CampusConnect\Entity\Student", inversedBy="studentAssignments")
* @ORM\JoinColumn(onDelete="CASCADE")
*/
private $student;