0

我知道完全相同类型的问题已经在这里发布了很多次。但没有一个人解决了我的问题,真的很沮丧,谷歌搜索了 2 多天,仍然没有成功。我被困在这里无法继续我的项目。我已经说明了我最后通过谷歌找到的解决方案,但没有解决我的问题。

这是我的规格:在 wamp 服务器/php 5.4.3/apache 2.2.22 上使用 Zend Framework 2.1.5 和教义OR​​MModule。

这是我在 Application/config/module.config.php 中的学说配置

    // Doctrine Configurations
'doctrine' => array(
        'driver' => array(
                // defines an annotation driver with two paths, and names it `my_annotation_driver`
                'my_annotation_driver' => array(
                        'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
                        'cache' => 'array',
                        'paths' => array(
                                __DIR__ . '/../src/Application/Model',
                        ),
                ),

                // default metadata driver, aggregates all other drivers into a single one.
                // Override `orm_default` only if you know what you're doing
                'orm_default' => array(
                        'drivers' => array(
                                // register `my_annotation_driver` for any entity under namespace `My\Namespace`
                                'Application\Model' => 'my_annotation_driver'
                        )
                )
        )
),
// End doctrine configurations

Application/src/Application/Model/User.php 中的用户实体类

namespace Application\Model;
/*
* @Entity
* @Table(name="user")
*/
class User
   {
/*
 * @Id 
 * @Column(type="integer")
 * @GeneratedValue(strategy="AUTO")
 */
private $id;

/*
 * @Column(type="string")
*/
private $username;

/*
 * @Column(type="string")
*/
private $password;

/*
 * @Column(type="string")
*/
private $email;

/*
 * @Column(type="string")
*/
private $name;

/*
 * @Column(type="string")
*/
private $profile_pic;

/*
 * @Column(type="string")
*/
private $cover_pic;

/*
 * @Column(type="integer")
*/
private $status;

/*
 * @Column(type="datetime")
*/
private $created_at;


public function getUsername()
{
    return $this->username;
}
}

Application/src/Application/Controller/UserController.php 中的 UserController

namespace Application\Controller;

use Zend\Mvc\Controller\AbstractActionController;
use Zend\View\Model\ViewModel;

class UserController extends AbstractActionController
{
public function IndexAction()
{
    $em = $this->getServiceLocator()->get('Doctrine\ORM\EntityManager');

    $user = $em->find('Application\Model\User', 1);
    var_dump($user);

    exit;
}
}

Url - public/application/user -> throws exception,下面是 stak 跟踪和错误

Doctrine\ORM\Mapping\MappingException
File:
C:\wamp\library\Doctrine\ORM\Mapping\MappingException.php:216
Message:
Class "Application\Model\User" is not a valid entity or mapped super class.
Stack trace:
0 C:\wamp\library\Doctrine\ORM\Mapping\Driver\AnnotationDriver.php(87):                Doctrine\ORM\Mapping\MappingException::classIsNotAValidEntityOrMappedSuperClass('Application\Mod...')
1     C:\wamp\library\Doctrine\Common\Persistence\Mapping\Driver\MappingDriverChain.php(104):     Doctrine\ORM\Mapping\Driver\AnnotationDriver->loadMetadataForClass('Application\Mod...',     Object(Doctrine\ORM\Mapping\ClassMetadata))
2 C:\wamp\library\Doctrine\ORM\Mapping\ClassMetadataFactory.php(113):     Doctrine\Common\Persistence\Mapping\Driver\MappingDriverChain-    >loadMetadataForClass('Application\Mod...', Object(Doctrine\ORM\Mapping\ClassMetadata))
3     C:\wamp\library\Doctrine\Common\Persistence\Mapping\AbstractClassMetadataFactory.php(302):     Doctrine\ORM\Mapping\ClassMetadataFactory-    >doLoadMetadata(Object(Doctrine\ORM\Mapping\ClassMetadata), NULL, false, Array)
4     C:\wamp\library\Doctrine\Common\Persistence\Mapping\AbstractClassMetadataFactory.php(205):     Doctrine\Common\Persistence\Mapping\AbstractClassMetadataFactory-    >loadMetadata('Application\Mod...')
5 C:\wamp\library\Doctrine\ORM\EntityManager.php(268): Doctrine\Common\Persistence\Mapping\AbstractClassMetadataFactory->getMetadataFor('Application\Mod...')
6 C:\wamp\library\Doctrine\ORM\EntityManager.php(682): Doctrine\ORM\EntityManager->getClassMetadata('Application\Mod...')
7 C:\wamp\www\indians\module\Application\src\Application\Controller\UserController.php(23): Doctrine\ORM\EntityManager->getRepository('Application\Mod...')
8 C:\wamp\library\Zend\Mvc\Controller\AbstractActionController.php(83): Application\Controller\UserController->IndexAction()
9 [internal function]: Zend\Mvc\Controller\AbstractActionController->onDispatch(Object(Zend\Mvc\MvcEvent))
10 C:\wamp\library\Zend\EventManager\EventManager.php(472): call_user_func(Array, Object(Zend\Mvc\MvcEvent))
11 C:\wamp\library\Zend\EventManager\EventManager.php(207): Zend\EventManager\EventManager->triggerListeners('dispatch', Object(Zend\Mvc\MvcEvent), Object(Closure))
12 C:\wamp\library\Zend\Mvc\Controller\AbstractController.php(117): Zend\EventManager\EventManager->trigger('dispatch', Object(Zend\Mvc\MvcEvent), Object(Closure))
13 C:\wamp\library\Zend\Mvc\DispatchListener.php(114): Zend\Mvc\Controller\AbstractController->dispatch(Object(Zend\Http\PhpEnvironment\Request), Object(Zend\Http\PhpEnvironment\Response))
14 [internal function]: Zend\Mvc\DispatchListener->onDispatch(Object(Zend\Mvc\MvcEvent))
15 C:\wamp\library\Zend\EventManager\EventManager.php(472): call_user_func(Array, Object(Zend\Mvc\MvcEvent))
16 C:\wamp\library\Zend\EventManager\EventManager.php(207): Zend\EventManager\EventManager->triggerListeners('dispatch', Object(Zend\Mvc\MvcEvent), Object(Closure))
17 C:\wamp\library\Zend\Mvc\Application.php(294): Zend\EventManager\EventManager->trigger('dispatch', Object(Zend\Mvc\MvcEvent), Object(Closure))
18 C:\wamp\www\indians\public\index.php(12): Zend\Mvc\Application->run()
19 {main}

我找到的解决方案:

  • 关闭 eaccelerator(我的 wamp 服务器上没有安装 eaccelerator,所以这不是问题)
  • 将注释映射 @Entity 更改为 @ORM\Entity (使用两者进行检查,并没有解决我的问题 - 似乎$config->newDefaultAnnotationDriver($path, true)第二个参数simpleannotationreader设置为 true。所以它会读取简单的注释 ex。@Entity虽然我通过使用检查@ORM\Entity仍然不起作用)
  • 我发现annotationRegistry::somemethod()如果这是解决方案我应该调用的某个地方,那么我应该从annotationRegistry课堂上调用哪个方法以及调用的确切位置在哪里。

cmd命令:

  • ./vendor/bin/doctrine-module orm:validate-schema显示没有错误 '[Mapping] OK - 映射文件是正确的。[数据库] OK - 数据库架构与映射文件同步。
  • 但是执行此命令 -`./vendor/bin/doctrine-module orm:info抛出异常如下“根据当前配置,您没有任何映射的 orm 实体。如果你有实体或映射文件,你应该检查你的映射配置是否有错误。

就是这样。现在我能做的就是保持我的希望和耐心。感谢您查看我的问题。

4

2 回答 2

3

我发现你的问题是什么:无效的评论。要描述 Doctrine 2 ORM 实体,您应该注释:

例如 - 而不是:

/*
 * @Id 
 * @Column(type="integer")
 * @GeneratedValue(strategy="AUTO")
 */
private $id;

你应该使用:

/**
 * @ORM\Id
 * @ORM\Column(type="integer")
 * @ORM\GeneratedValue(strategy="AUTO")
 */
private $id;

如前所述 - 您应该使用 Doctrine 2 ORM 中的注释,如下所示(以 @ORM\ 开头):

/**
 * @ORM\Column(type="string", length=31)
 */
private $username;

我鼓励您使用以下规则:所有实体都存储在子目录 Entity 中,并且在该实体上运行的函数 - 在子目录模型中(getUsers()、getUser(id) 等)。

在 User/src/User/Entity/User.php 中完成用户实体类(在我的例子中):

namespace User\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Users table
 *
 * @ORM\Entity
 * @ORM\Table(name="users")
 * @property int $id
 * @property string $username
 * @property string $password
 * @property string $email
 */
class User
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @ORM\Column(type="string", length=31)
     */
    private $username;

    /**
     * @ORM\Column(type="string", length=32)
     */
    private $password;

    /**
     * @ORM\Column(type="string", length=63)
     */
    private $email;

    /**
     * @ORM\Column(type="string", length=63)
     */
    private $name;

    /**
     * @ORM\Column(type="string", length=127)
     */
    private $profile_pic;

    /**
     * @ORM\Column(type="string", length=127)
     */
    private $cover_pic;

    /**
     * @ORM\Column(type="integer")
     */
    private $status;

    /**
     * @ORM\Column(type="datetime")
     */
    private $created_at;


    public function __construct() {
    }


    /**
     * Magic getter to expose protected properties.
     *
     * @param string $property
     * @return mixed
     */
    public function __get($property)
    {
        return $this->$property;
    }

    /**
     * Magic setter to save protected properties.
     *
     * @param string $property
     * @param mixed $value
     */
    public function __set($property, $value)
    {
        $this->$property = $value;
        return $this;
    }
}

当我想调用某个表时,我也使用复数形式。

例如用户文章帖子

实体名称的单数形式(单记录)

例如用户文章帖子

但这只是我正在使用的模式之一。

顺便提一句。感谢您提供有关 Doctrine 2 ORM 控制台工具的一些用法的信息。我从未使用过./doctrine-module orm:info,但只使用过 ./doctrine-module orm:schema-tool:create --dump-sql > database.sql

于 2013-05-07T20:53:24.540 回答
0

您的问题与 Docblock 注释“starter”字符有关:

Docblock 注释是以斜杠 (/) 和两个星号 (*)开头的 C++ 样式注释。这个“起始”字符是必需的, 否则 Doctrine 将无法识别注释

将所有注释更改为以 a 开头,/**它将起作用。

于 2016-11-28T13:12:42.733 回答