Ho un problema con Doctrine2 in Symfony2 e due entità correlate.Problema di symfony2 Doctrine2 con relazione uno a uno opzionale
Ciè un facile da entità che può (non deve) avere un'usermeta-entità di riferimento, che contiene informazioni come la biografia ecc
L'usermeta è facoltativa perché l'utente viene importato da un altro sistema, mentre è usermeta gestito nella mia applicazione.
Ovviamente voglio salvare entrambi insieme, in modo che il salvataggio di un utente debba creare o aggiornare un'entità usermeta.
Entrambi sono uniti da una colonna denominata aduserid (stesso nome in entrambe le tabelle).
Ho riconosciuto che se usermeta è un riferimento facoltativo il proprietario in questo caso deve essere usermeta, altrimenti la doctrina carica l'utente e ha bisogno dell'entità usermeta, ma non sempre è lì.
Si prega di notare i commenti in User-> setMeta ..
/**
* User
*
* @ORM\Table(name="user")
* @ORM\Entity
*/
class User
{
/**
* @var Usermeta
* @ORM\OneToOne(targetEntity="Usermeta", mappedBy="user", cascade={"persist"})
*/
protected $meta;
public function getMeta()
{
return $this->meta;
}
/**
*
* @param Usermeta $metaValue
*/
public function setMeta($metaValue)
{
// I've tried setting the join-column-value here
// - but it's not getting persisted
// $metaValue->setAduserid($this->getAduserid());
// Then I've tried to set the user-object in Usermeta - but then
// it seems like Doctrine wants to update Usermeta and searches
// for ValId names aduserid (in BasicEntityPersister->_prepareUpdateData)
// but only id is given - so not luck here
// $metaValue->setUser($this);
$this->meta = $metaValue;
}
/**
* @var integer
*
* @ORM\Column(name="rowid", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* Get rowid
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* @var integer
*
* @ORM\Column(name="ADuserid", type="integer", nullable=false)
*/
private $aduserid;
/**
* Set aduserid
*
* @param integer $aduserid
* @return User
*/
public function setAduserid($aduserid)
{
$this->aduserid = $aduserid;
return $this;
}
/**
* Get aduserid
*
* @return integer
*/
public function getAduserid()
{
return $this->aduserid;
}
// some mor fields....
}
e la classe Usermeta:
/**
* Usermeta
*
* @ORM\Table(name="userMeta")
* @ORM\Entity
*/
class Usermeta
{
/**
* @ORM\OneToOne(targetEntity="User", inversedBy="meta")
* @ORM\JoinColumn(name="ADuserid", referencedColumnName="ADuserid")
*/
protected $user;
public function getUser()
{
return $this->$user;
}
public function setUser($userObj)
{
$this->user = $userObj;
}
/**
* @var integer
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var integer
*
* @ORM\Column(name="ADuserid", type="integer", nullable=false)
*/
private $aduserid;
/**
* Set aduserid
*
* @param integer $aduserid
* @return User
*/
public function setAduserid($aduserid)
{
$this->aduserid = $aduserid;
return $this;
}
/**
* Get aduserid
*
* @return integer
*/
public function getAduserid()
{
return $this->aduserid;
}
}
il codice di controllo si presenta così:
...
$userForm->bind($request);
if($userForm->isValid()) {
$em->persist($user);
$em->flush();
}
...
non è il trucco per impostare meta - annullabile = true /** * @var Usermeta * @ORM \ OnetoOne (targetEntity = "Usermeta", mappedBy = "user" , cascade = {"persist"}, nullable = true) */ protetto $ meta; –
@Zdenek, l'annotazione OneToOne non ha parametri nullable. È un parametro di '@ JoinColumn'. – Athlan