Doctrine 2在flush上生成空id

时间:2012-06-20 02:01:06

标签: doctrine-orm flush persist string


关于stackoverflow的第一个问题,有点紧张。

所以,情况如下: 我正在使用Doctrine 2作为一个网站。我在没有梨的情况下正确安装它,使用我的应用程序中的好lib和良好的路径。我在开始编码之前创建了我的数据库,因此我使用逆向工程方法(doctrine exporter)创建了映射(xml& yml,以防万一)。生成的映射很好,然后我自己写了实体文件(控制台没有工作)。

/** @Entity */
class Member {

/** @Id @Column(type="string", nullable=false) */
private $login;
/** @Column(type="string", nullable=false) */
private $password;
/** @Column(type="string") */
private $mail;
/** */
private $dateregister;
/** */
private $datelastconnexion;
/** @Column(type="string") */
private $description;
/** */
private $birthday;
/** @Column(type="string") */
private $website;
/** @Column(type="boolean") */
private $activated;
/** @Column(type="integer") */
private $idstatus;
/** @Column(type="integer") */
private $idcountry;
/** @Column(type="integer") */
private $idlang;

/** @Column(type="integer") */
private $idarticle;
/** @Column(type="integer") */
private $idfilters;

public function __construct($login) {
    $this->login = $login;
    $this->activated = false;
}


public function getLogin() {return $this->login;}
public function getPassword() {return $this->password;}
public function getMail() {return $this->mail;}
public function getDateregister() {return $this->dateregister->format('Y/m/d');}
public function getDatelastconnexion() {if ($this->datelastconnexion == null) return 'Never logged';
    else return $this->datelastconnexion->format('Y/m/d H:i');}
public function getDescription() {return $this->description;}
public function getBirthday() {return $this->birthday->format('Y/m/d');}
public function getWebsite() {return $this->website;}
public function getActivated() {return $this->activated;}
public function getStatus() {return $this->idstatus;}
public function getCountry() {return $this->idcountry;}
public function getLang() {return $this->idlang;}
public function getArticles() {return $this->idarticle->toArray();}
public function getFilters() {return $this->idfilters->toArray();}

public function setLogin($newLogin) {$this->login = $newLogin;}
public function setPassword($newPassword) {$this->password = sha1($newPassword);}
public function setMail($newMail) {$this->mail = $newMail;}
public function setDateregister($newDate) {$this->dateregister = $newDate;}
public function setDatelastconnexion($newDate) {$this->datelastconnexion = $newDate;}
public function setDescription($newDescription) {$this->description = $newDescription;}
public function setBirthday($newDate) {$this->birthday = $newDate;}
public function setWebsite($newWebsite) {$this->website = $newWebsite;}
public function setActivated($activate) {$this->activated = $activate;}
public function setStatus($newStatus) {$this->idstatus = $newStatus;}
public function setCountry($newCountry) {$this->idcountry = $newCountry;}
public function setLang($newLang) {$this->idlang = $newLang;}
public function setArticles($newArticles) {$this->idarticle = $newArticles;}
public function setFilters($newFilters) {$this->idfilters = $newFilters;}

}

现在我试图在数据库中插入一些内容,但是我遇到了一个小问题: 当一个成员试图注册时,他会填写一些信息(登录,密码等)。我做了每一个测试,看看信息是否是正确的,如果它们是,我创建一个新的Object Member,我用每个给定的信息填充并自动生成一个,然后我在对象上调用persist(),然后flush()。< / p>

$newMember = new Member($login);
$newMember -> setPassword($passwd);
$newMember -> setMail($mail);
$newMember -> setDateregister($currentDate);
$newMember -> setDescription($description);
$newMember -> setBirthday($newBirthday);
$newMember -> setStatus($status[0]); // existing object
$newMember -> setCountry($country[0]); // existing object
$newMember -> setLang($lang[0]); // existing object
$doctrineManager->persist($newMember);
$doctrineManager->flush($newMember);

我惊讶地看着数据库,看到填充的ID等于''(空字符串),而不是$ login。 那么......那是我的问题:这怎么可能?是因为我在冲洗之前没有填写会员的所有财产吗?或者没有提供实体之间关系的信息(一对多,多对多,多对一)?或其他什么?我现在已经解决了这个问题一周了,我无法理解。

有关信息:

  • $ status,$ lang,$ country是外键。
  • $ article和$ filters是多对多的关系。

感谢您的阅读,并且(我希望)感谢您向我解释我的错误。

2 个答案:

答案 0 :(得分:0)

你必须像这样使用flush:

$doctrineManager->flush();

之后您可以使用以下方式访问ID:

$newmember->getId();

答案 1 :(得分:0)

事实是$ idarticle和$ idfilters是ManyToMany关系,我没有指定。在构造对象时,Doctrine 2可能无法根据映射构造对象。

所以构造函数看起来像这样:

public function __construct()
{
    $this->idfilters = new \Doctrine\Common\Collections\ArrayCollection();
    $this->idarticle = new \Doctrine\Common\Collections\ArrayCollection();
    $this->activated = false;
}

每个ManyToMany必须得到他们的ArrayCollections才能工作。