3

我已经定义了一个这样的类设置:

<?php

use Doctrine\ORM\Mapping as ORM;

/** @ORM\Entity */
class Setting {
    /** @ORM\Column(type="integer")
     *  @ORM\GeneratedValue
     *  @ORM\id
     */
    private $id;

    /** @ORM\Column(length=255, nullable=true) */
    private $displayname;

    /** @ORM\Column(length=255) */
    private $name;

    /** @ORM\Column(type="text") */
    private $value;

    public function __get($name) {
        return $this->$name;
    }

    public function __set($key, $value){
        $this->$key = $value;
    }

    public function getFullName() {
        return $this->name . ' suffix';
    }


    public static function getValue($settingName) {
        $result = '';
        try {
            $setting = em()->createQuery('SELECT s FROM Setting s WHERE s.name = :name')
                ->setParameter('name', $settingName)
                ->getSingleResult();

            $result = $setting->value;
        }
        catch (\Doctrine\ORM\NoResultException $exception) {

        }

        return $result;
    }
}

不幸的是,这给出了一个错误致命错误:Uncaught exception 'Doctrine\ORM\Mapping\MappingException' with message 'Class "Setting" is not a valid entity or mapped super class.' in xxxxx/vendor/doctrine/orm/lib/Doctrine/ORM/Mapping/MappingException.php on line 216

如何解决?

4

2 回答 2

3

为了解决这个问题,我不得不在最后一个参数中使用 false 调用Setup::createAnnotationMetadataConfiguration以避免使用 SimpleAnnotationReader,因为您需要 AnnotationReader 才能使用 ORM\ 命名空间前缀。

use Doctrine\ORM\Tools\Setup;
use Doctrine\ORM\EntityManager;

$dbParams = array(
    'driver' => 'pdo_mysql',
    'host' => '127.0.0.1',
    'user' => 'root',
    'password' => '', 
    'dbname' => 'db',
);

$path = __DIR__ . '/Entity';

$config = Setup::createAnnotationMetadataConfiguration(array($path), true, null, null, false);

$entityManager = EntityManager::create($dbParams, $config);
于 2013-04-03T15:00:35.570 回答
1

找到了解决方案:似乎问题在于使用 SimpleAnnotationReader。

当像这样配置 annotationDriver 时(第二个参数应该是 false),它可以工作。

$driver = $config->newDefaultAnnotationDriver(
    APPLICATION_PATH . '/models', false
);
于 2013-02-13T10:35:55.663 回答