Я пытаюсь понять Zend Framework 2. Для этого я начал с учебника Рона Аллена http://akrabat.com/getting-started-with-zend-framework-2/, затем я интегрировал учение 2, используя учебник http://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();
}
...
}
Но это не работает!Я получил это mensage:
"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?