2012-06-01 39 views
0

所以,我有两个班,他们之间的一对多和多对一的关系:主义2“类不存在”在坚持

 
namespace RM\Entity; 

use Doctrine\Common\Collections\ArrayCollection; 

/** 
* @Table(name="users") 
* @Entity 
* @author Csabi 
*/ 
class User { 

    /** 
    * @Id 
    * @Column(name="id", type="integer", nullable=false) 
    * @GeneratedValue(strategy="IDENTITY") 
    * @OneToMany(targetEntity="JobListing", mappedBy="ownerId", orphanRemoval=true) 
    */ 
    private $id; 

    /** 
    * @var string $displayname 
    * @Column(type="string", nullable=false) 
    */ 
    private $displayname; 
} 

 
namespace RM\Entity; 

use Doctrine\Common\Collections\ArrayCollection; 

/** 
* @Table(name="job_listings") 
* @Entity(repositoryClass="RM\Entity\Repository\JobListingRepository") 
* @author Csabi 
*/ 
class JobListing { 

    /** 
    * @var integer $id 
    * @Column(name="id", type="integer", nullable=false) 
    * @Id 
    * @GeneratedValue(strategy="IDENTITY") 
    */ 
    private $id; 

    /** 
    * @var User 
    * @ManyToOne(targetEntity="User",cascade={"persist"}) 
    * @JoinColumns({ 
    * @JoinColumn(name="ownerId", referencedColumnName="id", nullable=false) 
    * }) 
    */ 
    private $ownerId; 

然而,保存JobListing时,上坚持它会抛出以下错误:

 
Application error 
Exception information: 

Message: Class does not exist 
Stack trace: 

#0 library\Doctrine\ORM\Mapping\ClassMetadata.php(67): ReflectionClass->__construct(false) 
#1 library\Doctrine\ORM\Mapping\ClassMetadataFactory.php(350): Doctrine\ORM\Mapping\ClassMetadata->__construct(false) 
#2 library\Doctrine\ORM\Mapping\ClassMetadataFactory.php(260): Doctrine\ORM\Mapping\ClassMetadataFactory->newClassMetadataInstance(false) 
#3 library\Doctrine\ORM\Mapping\ClassMetadataFactory.php(169): Doctrine\ORM\Mapping\ClassMetadataFactory->loadMetadata(false) 
#4 library\Doctrine\ORM\EntityManager.php(247): Doctrine\ORM\Mapping\ClassMetadataFactory->getMetadataFor(false) 
#5 library\Doctrine\ORM\UnitOfWork.php(1222): Doctrine\ORM\EntityManager->getClassMetadata(false) 
#6 library\Doctrine\ORM\UnitOfWork.php(1678): Doctrine\ORM\UnitOfWork->doPersist(1, Array) 
#7 library\Doctrine\ORM\UnitOfWork.php(1252): Doctrine\ORM\UnitOfWork->cascadePersist(Object(RM\Entity\JobListing), Array) 
#8 library\Doctrine\ORM\UnitOfWork.php(1201): Doctrine\ORM\UnitOfWork->doPersist(Object(RM\Entity\JobListing), Array) 
#9 library\Doctrine\ORM\EntityManager.php(454): Doctrine\ORM\UnitOfWork->persist(Object(RM\Entity\JobListing)) 
#10 library\RM\Entity\JobListingService.php(54): Doctrine\ORM\EntityManager->persist(Object(RM\Entity\JobListing)) 
#11 application\controllers\JobListingController.php(28): RM\Entity\JobListingService->saveJobListing(Object(RM\Entity\JobListing)) 
#12 library\Zend\Controller\Action.php(516): JobListingController->addAction() 

我在这里错过了什么?

回答

2

问题实际上是在我试图保存的对象中。我没有将整个用户实体传递给ownerId,只有用户的id。

所以,当被调用的方法

Doctrine\ORM\UnitOfWork->doPersist(1, Array) 

它实际上是试图挽救一些,而不是用户实体。

这就是为什么错误“找不到类”的原因,因为没有类“1”。

1

您无法定义主键上的关系。尝试在用户类中添加另一个字段:

/** 
* @Table(name="users") 
* @Entity 
* @author Csabi 
*/ 
class User { 

    /** 
    * @Id 
    * @Column(name="id", type="integer", nullable=false) 
    * @GeneratedValue(strategy="IDENTITY") 
    */ 
    private $id; 

    /** 
    * @OneToMany(targetEntity="JobListing", mappedBy="ownerId", orphanRemoval=true) 
    */ 
    private $jobListings; 

    /** 
    * @var string $displayname 
    * @Column(type="string", nullable=false) 
    */ 
    private $displayname; 
} 
+0

我这样做,但它仍然给出相同的例外 –