4

Symfony2.1 プロジェクトで Doctrine2 を使用して (エンティティ経由で) テーブルからデータを取得しようとすると問題が発生します。エラーが発生するコントローラーは次のとおりです。

/**
 * Country list
 */
public function countrylistAction()
{
    $em = $this->getDoctrine()->getManager();
    $countryList = $em->getRepository('ProjectBaseBundle:SYS_TCountry')
        ->findAll();

    $serializer = new Serializer(array(new GetSetMethodNormalizer()),
        array('json' => new JsonEncoder()));

    return new Response($serializer->serialize($countryList, 'json'));
}

エンティティ:

<?php

namespace Company\Project\BaseBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;

/**
 * @ORM\Entity
 * @ORM\Table(name="SYS_TCountry")
 */
class SYS_TCountry
{
    /**
     * @ORM\Id
     * @ORM\Column(type="string", length=3, nullable=false)
     * @var string
     */
    protected $idcountry;

    /**
     * @ORM\Column(type="string", length=75, nullable=false)
     * @Assert\NotBlank()
     * @var string
     */
    protected $name;

    ....

    public function getIdcountry()              { return $this->idcountry; }
    public function getName()                   { return $this->name; }
    public function getA2()                     { return $this->a2; }
    public function getA3()                     { return $this->a3; }
    public function getIdstatus()               { return $this->idstatus; }
    public function setIdcountry($idcountry)    { $this->idcountry = $idcountry; }
    public function setName($name)              { $this->name = $name; }
    public function setA2($a2)                  { $this->a2 = $a2; }
    public function setA3($a3)                  { $this->a3 = $a3; }
    public function setIdstatus($idstatus)      { $this->idstatus = $idstatus; }

    public function __toString()                { return $this->idcountry; }

}

構成.yml:

# Doctrine Configuration
doctrine:
    dbal:
        driver:   %database_driver%
        host:     %database_host%
        port:     %database_port%
        dbname:   %database_name%
        user:     %database_user%
        password: %database_password%
        charset:  UTF8

    orm:
        auto_generate_proxy_classes: %kernel.debug%
        auto_mapping: true

そして、これはエラーです:

Warning: class_parents(): 
Class Company\Project\BaseBundle\Entity\SYS_TCountry does not exist and could not be loaded in 
/var/www/project/src/vendor/doctrine/common/lib/Doctrine/Common/Persistence/Mapping/RuntimeReflectionService.php line 40

Doctrine がコンソールで言うように、マッピングが適切に行われているため、奇妙です: php app/console doctrine:mapping:infoを実行してテストします:

[OK]   Company\Project\BaseBundle\Entity\SYS_TCountry

コンソールでクエリを実行すると、すべてうまくいきます-> app/console doctrine:query:sql 'SELECT * FROM SYS_TCountry', 結果が返されます。

Symfony2.1を使用して 2.0 バージョンとは異なる設定を行う必要があるかどうかはわかりませんが、マッピングは Doctrine の責任であるため、同じように見えます。

4

2 に答える 2

5

symfony は、ファイル名に関して PSR-0 標準に従います。これは、とりわけ、クラス名にアンダースコアを使用すると、クラスが存在する場所を決定するときに、次のようにディレクトリ区切り記号に置き換えられることを意味します。

\namespace\package\Class_Name => /path/to/project/lib/vendor/namespace/package/Class/Name.php

したがって、SYS_TCountry という名前のクラスがある場合、それは次の場所にあると予想されます。

Company/Project/BaseBundle/Entity/SYS/TCountry.php

それ以外の

Company/Project/BaseBundle/Entity/SYS_TCountry.php

あなたの最善の解決策は、ファイル名とクラス名を SYSTCountry に変更することだと思います。テーブル名を変更する必要はありません。

于 2012-07-27T15:52:00.000 に答える
1

クラス エンティティ名が準拠してPSR-0いないため、読み込みエラーが発生します。エンティティの名前をSYSTCountryすべてに変更すると、正常に動作します!

編集:デフォルトの Symfony2 および Doctrine オートローダー PSR-0準拠しています。

于 2012-07-27T15:38:39.443 に答える