我正在尝试使用Doctrine执行我的第一个DAO来执行列表方法。我的实体类是/ src / model / dto文件夹中的Canales.php
namespace model\dto;
use Doctrine\ORM\Mapping as ORM;
/**
* Canales
*
* @ORM\Table(name="Canales")
* @ORM\Entity
*/
class Canales
{
/**
* @var string
*
* @ORM\Column(name="Nombre", type="string", length=255, nullable=false)
*/
private $nombre;
/**
* @var integer
*
* @ORM\Column(name="Id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* Class Constructor
* @param $nombre
* @param $id
*/
public function __construct($nombre, $id)
{
$this->nombre = $nombre;
$this->url = $url;
$this->imagen = $imagen;
$this->ingles = $ingles;
$this->id = $id;
}
/**
* Set nombre
*
* @param string $nombre
* @return Canales
*/
public function setNombre($nombre)
{
$this->nombre = $nombre;
return $this;
}
/**
* Get nombre
*
* @return string
*/
public function getNombre()
{
return $this->nombre;
}
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
}
这个类是使用这些行生成的
vendor / bin / doctrine orm:convert-mapping --from-database xml config / xml /
vendor / bin / doctrine orm:generate-entities --generate-annotations = true --regenerate-entities = true src /
我的Dao类(在/ src / model / dao文件夹中)
class daoGenerico{
private $entityManager;
/**
* Class Constructor
* @param $entityManager
*/
public function __construct()
{
require_once("bootstrap.php");
$this->entityManager = $entityManager;
}
/**
* @return mixed
*/
public function getEntityManager()
{
return $this->entityManager;
}
function showAction(){
$repository = $this->getEntityManager()->getRepository('model\dto\Canales');
//->find($id);
echo "..";
$productos = $repository->findAll();
echo "OK";
if (!$productos) {
throw $this->createNotFoundException(
'No product found'
);
}
else{
var_dump($productos);
}
}
}
我的bootstrap.php
// bootstrap.php
use Doctrine\ORM\Tools\Setup;
use Doctrine\ORM\EntityManager;
require_once "vendor/autoload.php";
// Create a simple "default" Doctrine ORM configuration for Annotations
$isDevMode = true;
$config = Setup::createAnnotationMetadataConfiguration(array(__DIR__."/src/model/dto"), $isDevMode);
// database configuration parameters
$conn = array(
'driver' => 'pdo_mysql',
'host' => 'localhost',
'user' => 'root',
'password' => 'root',
'dbname' => 'yoga',
'charset' => 'UTF8',
);
// obtaining the entity manager
$entityManager = EntityManager::create($conn, $config);
和我的test.php文件
include_once('./src/model/dao/daoGenerico.php');
$daoGenerico = new daoGenerico();
$daoGenerico->showAction();
composer.json就是这个
{
"require": {
"doctrine/orm": "2.4.*"
},
"autoload": {
"psr-0": {"": "src/"}
}
}
当我执行它时,我有这个错误
致命错误:未捕获的异常'Doctrine \ ORM \ Mapping \ MappingException',消息'Class'model \ dto \ Canales“不是有效的实体或映射的超类。”在/Applications/MAMP/htdocs/yoga/vendor/doctrine/orm/lib/Doctrine/ORM/Mapping/MappingException.php:336
我在stackoverflow中尝试了一些类似的问题但没有结果。有什么想法或建议吗?
答案 0 :(得分:1)
我已经解决了我的问题。我不得不改变我的bootstrap.php,这一行
$config = Setup::createAnnotationMetadataConfiguration(array(DIR."/src/model/dto"), $isDevMode, null, null, false);