[英]Symfony 3 Doctrine undefined index
我正在嘗試使用該學說從MySQL數據庫中獲取一個對象。 它與另一個具有一對一的關系。 我收到此錯誤: Notice: Undefined index: id
我應該糾正些什么才能使它正常工作? 我的獲取代碼非常簡單,我嘗試獲取所有對象:
$emArt = $this->getDoctrine()->getRepository(Article::class);
$articles = $emArt->findAll();
型號如下:
Article.php
/** * @ORM\\Entity * @ORM\\Table(name="Article") */ class Article { /** * @ORM\\Column(type="integer") * @ORM\\Id * @ORM\\GeneratedValue(strategy="AUTO") */ private $ID; /** * @ORM\\OneToOne(targetEntity="ArticleTypes", inversedBy="articleTypeId") * @ORM\\JoinColumn(name="articleTypeId", referencedColumnName="id") */ private $articleType; /** * @ORM\\Column(name="articleName", type="text") */ private $articleName; /** * @ORM\\Column(name="content", type="text") */ private $content; /** * @ORM\\Column(name="image", type="string") * @Assert\\File(mimeTypes={ "image/png" }) */ public $image; public function getArticleImage() { return $this->image; } public function setArticleImage($newImage) { $this->image = $newImage; } public function getArticleContent() { return $this->content; } public function setArticleContent($name) { $this->content = $name; } public function getArticleName() { return $this->articleName; } public function setArticleName($name) { $this->articleName = $name; } public function getArticleType() { return $this->articleType; } public function setArticleType($type) { $this->articleType = $type; } }
ArticleTypes.php
/** * @ORM\\Entity * @ORM\\Table(name="ArticleTypes") */ class ArticleTypes { /** * @ORM\\Column(type="integer") * @ORM\\Id * @ORM\\GeneratedValue(strategy="AUTO") * @ORM\\OneToOne(targetEntity="Article", mappedBy="articleTypeId") */ private $ID; /** * @ORM\\Column(name="articleType", type="text") */ private $articleType; public function getArticleType() { return $this->articleType; } public function setArticleType($newType) { $this->articleType = $newType; } }
這是PHP聲明,不是嗎? 您還應該在文件中具有錯誤的行號嗎?
但是我也看到了您的學說映射中的錯誤:您不能在字段中使用這樣的學說注釋,您應該將關系鏈接到對象:
/**
* @ORM\Entity
* @ORM\Table(name="Article")
*/
class Article
{
/**
* @ORM\OneToOne(targetEntity="ArticleTypes", inversedBy="article")
* @ORM\JoinColumn(name="articleTypeId", referencedColumnName="id")
*/
private $articleType;
....
}
和:
/**
* @ORM\Entity
* @ORM\Table(name="ArticleTypes")
*/
class ArticleTypes
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var Article $article
* @ORM\OneToOne(targetEntity="Article", mappedBy="articleType")
*/
private $article;
....
}
即使您具有一對一的關系,您也可以具有不同的ID。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.