Symfony Doctrine Many to Many Relationship (ManyToMany)

Many to many relations are one of the mostly used relations in the relational database. It took a while for me to figure how to properly configure this relation in Symfony Doctrine. I am sharing this so it might be useful for someone.

Used very simple example students and course. A student can opt for multiple courses and a single course can be opted by multiple students.

And Entity class should be like this…

namespace AppBundle\Entity;

use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Mapping as ORM;


class Student
{
    
    private $id;

    
    private $name;

    
    private $email;

    
    private $dob;

    
    private $courses;

    public function __construct()
    {
        $this->courses = new ArrayCollection();
    }

    
    public function getId()
    {
        return $this->id;
    }

    
    public function setName($name)
    {
        $this->name = $name;

        return $this;
    }

    
    public function getName()
    {
        return $this->name;
    }

    
    public function setEmail($email)
    {
        $this->email = $email;

        return $this;
    }

    
    public function getEmail()
    {
        return $this->email;
    }

    
    public function setDob($dob)
    {
        $this->dob = $dob;

        return $this;
    }

    
    public function getDob()
    {
        return $this->dob;
    }

    
    public function getCourses()
    {
        return $this->courses;
    }

    
    public function setCourses($courses)
    {
        $this->courses = $courses;
    }

}

namespace AppBundle\Entity;

use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Mapping as ORM;


class Course
{
    
    private $id;

    
    private $name;


    
    private $students;

    public function __construct()
    {
        $this->students = new ArrayCollection();
    }

    
    public function getId()
    {
        return $this->id;
    }

    
    public function setName($name)
    {
        $this->name = $name;

        return $this;
    }

    
    public function getName()
    {
        return $this->name;
    }

    
    public function getStudents()
    {
        return $this->students;
    }

    
    public function setStudents($students)
    {
        $this->students = $students;
    }

}

The above entities will create the following SQL and it will also create the cross-reference table.

CREATE TABLE ab_student 
  ( 
     id    INT auto_increment NOT NULL, 
     name  VARCHAR(255) NOT NULL, 
     email VARCHAR(255) NOT NULL, 
     dob   DATETIME NOT NULL, 
     PRIMARY KEY(id) 
  ) 
DEFAULT CHARACTER SET utf8 
COLLATE utf8_unicode_ci 
engine = innodb; 

CREATE TABLE ab_student_2_course 
  ( 
     course_id  INT NOT NULL, 
     student_id INT NOT NULL, 
     INDEX idx_87d76467591cc992 (course_id), 
     INDEX idx_87d76467cb944f1a (student_id), 
     PRIMARY KEY(course_id, student_id) 
  ) 
DEFAULT CHARACTER SET utf8 
COLLATE utf8_unicode_ci 
engine = innodb; 

CREATE TABLE ab_course 
  ( 
     id   INT auto_increment NOT NULL, 
     name VARCHAR(255) NOT NULL, 
     PRIMARY KEY(id) 
  ) 
DEFAULT CHARACTER SET utf8 
COLLATE utf8_unicode_ci 
engine = innodb; 

ALTER TABLE ab_student_2_course 
  ADD CONSTRAINT fk_87d76467591cc992 FOREIGN KEY (course_id) REFERENCES 
  ab_student (id) ON DELETE CASCADE; 

ALTER TABLE ab_student_2_course 
  ADD CONSTRAINT fk_87d76467cb944f1a FOREIGN KEY (student_id) REFERENCES 
  ab_course (id) ON DELETE CASCADE; 

Hope this helps 😉

Previous Article

Why do we need to upgrade PHP 5.6 to PHP 7.2?

Next Article

Thanks to GDPR companies are too smart these days