sql >> Databáze >  >> RDS >> Mysql

Žádné namapované entity ORM Doctrine podle aktuální konfigurace

Ukázalo se, že standardní nastavení konfigurace Doctrine [1] nefunguje s mojí kódovou bází ani s žádnou kódovou bází, se kterou jsem testoval, možná jsou dokumenty zastaralé. Po několika hodinách procházení Interwebů je to konfigurace, díky které mi to konečně fungovalo:

use Doctrine\ORM\Tools\Setup;
use Doctrine\ORM\EntityManager;
use Doctrine\Common\Annotations\AnnotationReader;

$paths = array( realpath(__DIR__."/../src/My/Entity") );
$isDevMode = TRUE;

// the connection configuration
$dbParams = array(
    'driver'   => 'pdo_mysql',
    'user'     => 'myuser',
    'password' => 's3cr3t',
    'dbname'   => 'mydb',
);

$cache = new \Doctrine\Common\Cache\ArrayCache();

$reader = new AnnotationReader();
$driver = new \Doctrine\ORM\Mapping\Driver\AnnotationDriver($reader, $paths);

$config = Setup::createAnnotationMetadataConfiguration($paths, $isDevMode);
$config->setMetadataCacheImpl( $cache );
$config->setQueryCacheImpl( $cache );
$config->setMetadataDriverImpl( $driver );

$entityManager = EntityManager::create($dbParams, $config);

//-- This I had to add to support the Mysql enum type.
$platform = $entityManager->getConnection()->getDatabasePlatform();
$platform->registerDoctrineTypeMapping('enum', 'string');

[1] http://docs.doctrine-project. org/en/latest/tutorials/getting-started.html



  1. Připojení ke stejnému stolu více než jednou

  2. Jak najdu uloženou proceduru obsahující <text>?

  3. Vytváření a nasazení více verzí databáze prostřednictvím snímků schématu

  4. Jak zapíšete podmínku do příkazu MySQL select?