3

我收到“Class PriceOrQuality\POQBundle\Entity\Tag 不是有效实体或映射的超类错误。我已经检查了类似问题的所有答案,但我似乎无法理解问题所在。

我的存储库类引发了错误

<?php

namespace PriceOrQuality\POQBundle\Entity\Repository;

use Doctrine\ORM\EntityRepository as ER;
use PriceOrQuality\POQBundle\Entity\Tag;
use Doctrine\ORM\EntityManager;

/**
 * EntityTagsRepository
 *
 */
class EntityTagsRepository extends ER
{
    public function getTagsForTagCloud($entity_ids = null, $tag_id = null) {

        $em = $this->getEntityManager();

        $qb = $em->createQueryBuilder();
        $qb->select(array('IDENTITY(et.tag) as id, COUNT(et.tag) as tag_id_count, LOWER(t.tag) as tag'));
        $qb->from('PriceOrQuality\POQBundle\Entity\EntityTag', 'et');
        $qb->leftjoin('PriceOrQuality\POQBundle\Entity\Tag','t', 'WITH', 'et.tag = t.id');
        $qb->groupBy('et.tag');
        $qb->addOrderBy('tag_id_count','DESC');
        $qb->setMaxResults(20);      
        return $qb->getQuery()
                ->getResult();
    }
}

Tag 类在此文件 (Tag.php) 中定义(仅定义):

<?php

namespace PriceOrQuality\POQBundle\Entity;

// src/PriceOrQuality/POQBundle/Entity/Tag.php

use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
use PriceOrQuality\POQBundle\Entity\EntityTag;
use PriceOrQuality\POQBundle\Entity\User;
use JMS\SerializerBundle\Serializer\Serializer;

/**
 * @ORM\Entity(repositoryClass="PriceOrQuality\POQBundle\Entity\Repository\TagsRepository")
 * @ORM\Table(name="tags")
 * @ORM\HasLifecycleCallbacks 
 */

你们中的任何一个聪明人都知道从哪里开始调试吗?

提前致谢,

符文

4

2 回答 2

11

发现问题。

在元定义之后和类定义之前,我有一个 //@todo。显然,这搞砸了映射,因为它没有在教义中映​​射。

移动 //@todo 并重新运行映射解决了这个问题。

对于发现此问题有类似问题的人,请尝试运行:

php app/console doctrine:mapping:info

如果您在学说中的映射结构有问题,它会告诉您

谢谢你们的时间。

干杯,符文

于 2013-07-21T08:39:51.930 回答
0

阅读一下查询生成器。它比 sql 查询更容易且不同。不需要加入条件。

这(对于初学者):

$qb->leftjoin('PriceOrQuality\POQBundle\Entity\Tag','t', 'WITH', 'et.tag = t.id');

应该只是:

$qb->leftJoin('et.tag','t');

可能会有更多问题,但这会让你开始。 http://docs.doctrine-project.org/en/latest/reference/query-builder.html

于 2013-07-20T19:32:44.693 回答