【发布时间】:2014-04-30 07:59:34
【问题描述】:
我有两张表,一张是产品,另一张是类别。我首先创建了产品并通过终端生成了数据库模式。当我将以下字段添加到产品实体时:
/**
* @ORM\ManyToOne(targetEntity="Category", inversedBy="products")
* @ORM\JoinColumn(name="category_id", referencedColumnName="id")
*/
protected $category;
然后我将产品字段添加到类别实体中,如下所示:
/**
* @ORM\OneToMany(targetEntity="Product", mappedBy="category")
*/
protected $products;
public function __construct()
{
$this->products = new ArrayCollection();
}
当我在终端输入以下命令时:
php console doctrine:schema:update --force
上面写着Nothing to update - your database is already in sync with the current entity metadata.
对于最后一步,我什至删除了产品和类别表并通过以下命令生成它们:
php console doctrine:schema:update --force
两个表都已创建,但无法添加 category_id。
我遵循了 symfony 的官方书籍。这里有什么我错过的吗?
我在通过 shell 创建实体后手动添加了 category_id 及其元数据
编辑::
产品实体:
<?php
namespace Acme\StoreBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* Product
*/
class Product
{
/**
* @var integer
*/
private $id;
/**
* @var string
*/
private $name;
/**
* @var string
*/
private $price;
/**
* @var string
*/
private $description;
/**
* @ORM\ManyToOne(targetEntity="Category", inversedBy="products")
* @ORM\JoinColumn(name="category_id", referencedColumnName="id")
*/
protected $category;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set name
*
* @param string $name
* @return Product
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Set price
*
* @param string $price
* @return Product
*/
public function setPrice($price)
{
$this->price = $price;
return $this;
}
/**
* Get price
*
* @return string
*/
public function getPrice()
{
return $this->price;
}
/**
* Set description
*
* @param string $description
* @return Product
*/
public function setDescription($description)
{
$this->description = $description;
return $this;
}
/**
* Get description
*
* @return string
*/
public function getDescription()
{
return $this->description;
}
}
类别实体:
<?php
namespace Acme\StoreBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
/**
* Category
*/
class Category
{
/**
* @var integer
*/
private $id;
/**
* @var string
*/
private $name;
/**
* @ORM\OneToMany(targetEntity="Product", mappedBy="category")
*/
protected $products;
public function __construct()
{
$this->products = new ArrayCollection();
}
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set name
*
* @param string $name
* @return Category
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}
}
【问题讨论】:
-
你试过删除缓存吗?
-
你是否用
@ORM\Entity标记了两个实体类? -
我在两个课程中都使用了
namespace Acme\StoreBundle\Entity;。 -
@phpGeek 请用实体类的完整源代码更新问题。
-
@JakubPolák,我也试过了,但没有成功
标签: mysql symfony doctrine-orm metadata