Warum funktioniert meine Symfony2 @UniqueEntity-Einschränkung überhaupt nicht?
Ich habe die folgende Entitätsklasse in meiner Anwendung:
<?php
namespace ...;
// use ...
use Doctrine\ORM\Mapping as ORM;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;;
// ...
/**
* @ORM\Table(name="sc_user")
* @ORM\Entity(repositoryClass="...\UserRepository")
* @ORM\HasLifecycleCallbacks()
* @UniqueEntity(fields={"email", "username"})
*/
class User implements UserInterface, \Serializable, EquatableInterface
{
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string $email
*
* @ORM\Column(name="email", type="string", length=255, unique=true)
*
* @Assert\NotBlank(groups={"registration"})
* @Assert\Email(groups={"registration"})
*/
private $email;
/**
* @var string $username
*
* @ORM\Column(name="username", type="string", length=32, unique=true)
*
* @Assert\NotBlank(groups={"registration"})
*/
private $username;
// ...
}
Die @ UniqueEntity-Einschränkung wird ignoriert. Ich habe verschiedene Geschmacksrichtungen ausprobiert, darunter:
@UniqueEntity(fields={"email", "username"})
und
@UniqueEntity(fields={"email"})
@UniqueEntity(fields={"username"})
und gemäß der Symfony2-Dokumentation hier:http://symfony.com/doc/current/reference/constraints/UniqueEntity.html
@UniqueEntity("email")
@UniqueEntity("username")
Nichts was ich tue, funktioniert. Anstatt wie erwartet einen Formularüberprüfungsfehler zu erhalten, wird die folgende Ausnahme angezeigt:
SQLSTATE [23000]: Verletzung der Integritätsbedingung: 1062 Doppelter Eintrag '[email protected]' für Schlüssel 'UNIQ_D8183973E7927C74'
Das ist einfach falsch! Weiß jemand, wie man dieses Problem behebt?