Я создаю свои сущности и хочу создать сущность с двумя столбцами, которые должны иметь определенное ограничение.Если addressId определен, то extAddressId может быть нулевым (и оно должно быть нулевым).
/**
* @ORM\Entity()
* @ORM\Table(name="widgets")
*/
class Widget
{
/**
* @ORM\Id()
* @ORM\GeneratedValue()
* @ORM\Column(type="integer")
*/
private $id;
/**
* @ORM\Column(type="integer")
*/
private $addressId;
/**
* @ORM\Column(type="integer")
*/
private $extAddressId;
}
Я знаю, как сделать это с SQL, но не с доктриной.
CREATE TABLE widgets
(
id integer,
addressId integer,
extAddressId integer,
CONSTRAINT if_addressId_then_extAddressId_is_not_null
CHECK ( (NOT addressId) OR (extAddressId IS NOT NULL) )
);