关于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。 那么......那是我的问题:这怎么可能?是因为我在冲洗之前没有填写会员的所有财产吗?或者没有提供实体之间关系的信息(一对多,多对多,多对一)?或其他什么?我现在已经解决了这个问题一周了,我无法理解。
有关信息:
感谢您的阅读,并且(我希望)感谢您向我解释我的错误。
答案 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才能工作。