3

我正在尝试理解 Zend Framework 2。为此,我从 Ron Allen 的教程http://akrabat.com/getting-started-with-zend-framework-2/开始, 然后,我使用教程http集成了学说 2 ://www.jasongrimes.org/2012/01/using-doctrine-2-in-zend-framework-2/ 好的,在此之前我决定让它更复杂。

我将数据库更改为以下内容:

--
-- Estrutura da tabela `album`
--
CREATE TABLE IF NOT EXISTS `album` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `artist_id` int(11) NOT NULL,
  `title` varchar(100) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `artist` (`artist_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=16 ;

--
-- Estrutura da tabela `artist`
--
CREATE TABLE IF NOT EXISTS `artist` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;

我的应用程序具有以下结构:

module
    Album
        src
            Album
                Controller
                    AlbumController.php
                Entity
                    Album.php
    Artist
        src
            Artist
                Controller
                    ArtistController.php
                Entity
                    Artist.php

我的新实体是这样的:

class Album {

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

    /**
     * @ORM\Column(type="string")
     */
    protected $title;

    /**
     * @ORM\ManyToOne(targetEntity="Artist", inversedBy="album")
     * @ORM\JoinColumn(name="artist_id", referencedColumnName="id")
     */
    protected $artist;

    ...
}
class Artist {

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

    /**
     * @ORM\Column(type="string")
     */
    protected $name;

    /**
     * @ORM\OneToMany(targetEntity="Album", mappedBy="artist")
     */
    protected $album;


    public function __construct()
    {
        $this->album = new ArrayCollection();
    }

    ...
}

但它不起作用!我得到了这个消息:

"The target-entity Album\Entity\Artist cannot be found in 'Album\Entity\Album#artist'."

所以我的问题是:怎么了?我的实体在错误的地方?还是我的模块组织不好?如何使一个实体对多个模块可见?

更新:

我将我的实体更改为:

class Album {

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

    /**
     * @ORM\Column(type="string")
     */
    protected $title;

    /**
     * @ORM\ManyToOne(targetEntity="\Artist\Entity\Artist", inversedBy="album")
     * @ORM\JoinColumn(name="artist_id", referencedColumnName="id")
     */
    protected $artist;

    ...
}
class Artist {

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

    /**
     * @ORM\Column(type="string")
     */
    protected $name;

    /**
     * @ORM\OneToMany(targetEntity="\Album\Entity\Album", mappedBy="artist")
     */
    protected $album;

    ...
}

但我得到了同样的错误:

"The target-entity Artist\Entity\Artist cannot be found in 'Album\Entity\Album#artist'."

更新 2:

我将应用程序的结构更改为:

module
    Album
        src
            Album
                Controller
                    AlbumController.php
                    ArtistController.php
                Entity
                    Album.php
                    Artist.php

所以我的实体在同一个命名空间中,现在我的程序正在运行!=)

但是我仍然有一个问题:我怎样才能让一个实体对 ZF2 中的多个 mudule 可见?

4

3 回答 3

2

我找到了答案!=D

我要等 8 个小时才能回答我自己的问题,所以我们开始吧。

正如我所说,我复制了教程http://www.jasongrimes.org/2012/01/using-doctrine-2-in-zend-framework-2/

他们教如何配置模块以使用 Doctrine 2。在文件 module/Album/config/module.config.php 中,他们插入以下代码:

return array(
    'di' => array(
        'instance' => array(
            // ...
            'orm_driver_chain' => array(
                'parameters' => array(
                    'drivers' => array(
                        'Album' => array(
                            'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
                            'namespace' => __NAMESPACE__ . '\Entity',
                            'paths' => array(
                                __DIR__ . '/../src/' . __NAMESPACE__ . '/Entity'
                            ),
                        ),
                    ),
                ),
            ),

根据教程:

“这告诉 Doctrine,Album 模块的实体使用命名空间 Album\Entity,并且该命名空间中的类存储在 $PROJECT_DIR/module/Album/src/Album/Entity 中。”

所以,有问题!教义被配置为仅使用专辑\实体!所以我将代码更改为以下(编程错误......对不起):

//...
'drivers' => array(
    'Album' => array(
        'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
        'namespace' => __NAMESPACE__ . '\Entity',
        'paths' => array(
            __DIR__ . '/../src/' . __NAMESPACE__ . '/Entity'
        ),
    ),
    'Artist' => array(
        'class' => 'Doctrine\ORM\Mapping\Driver\AnnotationDriver',
        'namespace' => '\Artist\Entity',
        'paths' => array(
            __DIR__ . '/../../Artist/src/Artist/Entity'
        ),
    ),
//...

如您所见,我配置了一个“艺术家”驱动程序...

现在我的应用程序可以正常工作了!=)

我仍在寻找在我的应用程序中配置该学说的正确方法,但至少我得到了答案!

谢谢大家!:)

于 2012-02-28T11:36:25.707 回答
1

关于您更新的问题:

您的实体和一个模块中使用的所有其他代码在每个其他模块中都是“可见的”,只需通过实例化它

$artist = new \Album\Entity\Artist();

或您可能需要的任何东西。只需确保在应用程序配置中注册了所有模块。

于 2012-02-27T18:56:14.223 回答
0

默认情况下,Doctrine 2 将在与当前实体相同的命名空间中查找相关实体。就像是:

 * @ORM\ManyToOne(targetEntity="\Artist\Entity\Artist", inversedBy="album")

将需要。免责声明:我没有使用过 ZF2。我假设您的类加载器路径都已设置。

于 2012-02-27T16:29:11.657 回答