An en User
a un Package
associé. De nombreux utilisateurs peuvent se référer au même package. User
ne peut exister sans un Package
défini. User
devrait posséder la relation. La relation est bidirectionnelle, donc a Package
n'a aucun utilisateur ou plus.
Ces exigences mènent à la ManyToOne
relation pour User
et à la OneToMany
relation de Package
dans Doctrine 2. Cependant, package_id
dans la user
table (c'est-à-dire la clé étrangère) autorise les null
valeurs. J'ai essayé de régler nullable=false
mais commande:
php app/console doctrine:generate:entities DL --path="src" --no-backup
Dit qu'il n'y a pas d'attribut nullable
pour la relation ManyToOne
. Qu'est-ce qu'il me manque?
class User
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\ManyToOne(targetEntity="Package", inversedBy="users")
*/
private $package;
}
class Package
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\OneToMany(targetEntity="User", mappedBy="package")
*/
private $users;
}
EDIT : résolu. veuillez noter que c'est faux (notez les guillemets):
@ORM\JoinColumn(name="package_id", referencedColumnName="id", nullable="false")
Bien que ce soit correct:
@ORM\JoinColumn(name="package_id", referencedColumnName="id", nullable=false)
package_id
est toujours marquée comme Null - Oui, par défaut - NULL. Toute aide est très appréciée.