如何在Symfony 3中联接3个表
这是我的队形课:如何在Symfony 3中联接3个表,symfony,doctrine-orm,doctrine,dql,symfony-3.2,Symfony,Doctrine Orm,Doctrine,Dql,Symfony 3.2,这是我的队形课: class Formation { /** * @var int * * @ORM\Column(name="id", type="integer") * @ORM\Id * @ORM\GeneratedValue(strategy="AUTO") */ private $id; /** * @var string * * @ORM\Column(name="nom", type="string", length=150, unique=true) */
class Formation
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
*
* @ORM\Column(name="nom", type="string", length=150, unique=true)
*/
private $nom;
/**
* @var string
*
* @ORM\Column(name="description", type="text")
*/
private $description;
/**
* @var string
*
* @ORM\Column(name="duree", type="string", length=100)
*/
private $duree;
/**
* @var string
*
* @ORM\Column(name="difficulte", type="string", length=100)
*/
private $difficulte;
/**
* @var string
*
* @ORM\Column(name="prerequis", type="text")
*/
private $prerequis;
/**
* @var bool
*
* @ORM\Column(name="is_active", type="boolean" , options={"default":false})
*/
private $is_active;
/**
* @ORM\ManyToOne(targetEntity="Category", inversedBy="formations")
* @ORM\JoinColumn(name="category_id", referencedColumnName="id")
*/
private $category;
/**
* @ORM\ManyToMany(targetEntity="Formatteur", mappedBy="formations")
*/
private $formatteurs;
//getter & setter ...
}
这是我的Formatteur课程:
class Formatteur
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
*
* @ORM\Column(name="nom", type="string", length=255)
*/
private $nom;
/**
* @var string
*
* @ORM\Column(name="prenom", type="string", length=100)
*/
private $prenom;
/**
* @var string
*
* @ORM\Column(name="bio", type="string", length=100)
*/
private $bio;
/**
* @var string
*
* @ORM\Column(name="email", type="string", length=255, unique=true)
*/
private $email;
/**
* @var string
*
* @ORM\Column(name="specialite", type="string", length=100)
*/
private $specialite;
/**
* @var int
*
* @ORM\Column(name="Age", type="integer")
*/
private $age;
/**
* @var bool
*
* @ORM\Column(name="is_active", type="boolean" , options={"default":false})
*/
private $is_active;
/**
* @ORM\ManyToMany(targetEntity="Formation", inversedBy="formatteurs")
* @ORM\JoinTable(name="formation_formatteur")
*/
private $formations;
//getter & setter ...
}
一个格式化师可以制作很多种格式。
编队可以由几个格式化程序创建。
我有3张表格:表格、格式化程序和格式化程序。
我想编写一个查询,返回三个表中的所有信息。我该怎么做
以下是我的尝试:
$query = $this->getEntityManager()->createQuery("SELECT FR,FN,T FROM
ElearingBundle:Formation FN INNER JOIN ElearingBundle:Formatteur FR WITH
FR.id=T.formateur INNER JOIN formation_formateur T WITH FN.id=I.formation");
我看到了你们的实体定义,你们在形式和格式之间有很多关系,为了从这些实体中获取所有信息,你们可以写在DQL下面
SELECT FN,FR
FROM ElearingBundle:Formation FN
INNER JOIN FN.formatteurs FR
注意:我的user仅用于ElearingBundle:Formation,没有其他实体,在连接部分中,我使用了Formation中定义的属性,因为原则本身标识关系类型,并将执行连接部分,就像您不必在DQL中指定表名一样
上面的DQL将生成与下面类似的SQL
SELECT FN.*,FR.*
FROM formation FN
JOIN formation_formateur FF ON FF.formation_id = FN.id
JOIN formateur FR ON FF.formateur_id = FR.id
请参阅我的其他相关答案
SELECT FN.*,FR.*
FROM formation FN
JOIN formation_formateur FF ON FF.formation_id = FN.id
JOIN formateur FR ON FF.formateur_id = FR.id