2016-09-22 69 views
0

我想將自定義類型映射到字符串。這裏是我的實體定義:zend表達+教條自定義類型

/** 
* @var string 
* 
* @ORM\Column(name="type", type="string", columnDefinition="my_type_enum", nullable=false) 
*/ 

但是當我嘗試創建遷移(遷移:DIFF)這是輸出

[主義\ DBAL \ DBALException] 未知的數據庫類型my_type_enum要求,Doctrine\DBAL\Platforms\PostgreSQL92Platform不得suppo rt it。

似乎我需要映射我的自定義類型my_type_enum到一個字符串使用mapping_types,但在Zend表達?它似乎我的配置被忽略

... 
    'doctrine' => [ 
     'dbal' => [ 
     'mapping_types' => [ 
      'my_type_enum' => 'string' 
     ] 
     ] 
    ] 
... 

回答

2

Zend的表現力的本身並沒有在教義支持的版本。這取決於學說模塊及其工廠,您正在使用。工廠使用配置啓動教條服務。所以我會在教條工廠裏面找出它是如何以及它是否支持自定義映射類型。

如果您不支持它,您可以使用container-interop-doctrine。它有這個built in似乎支持(還沒有嘗試過我自己):

<?php 
return [ 
    'doctrine' => [ 
     // ... 
     'connection' => [ 
      'orm_default' => [ 
       'driver_class' => \Doctrine\DBAL\Driver\PDOMySql\Driver::class, 
       'wrapper_class' => null, 
       'pdo' => null, 
       'configuration' => 'orm_default', 
       'event_manager' => 'orm_default', 
       'params' => [], 
       'doctrine_mapping_types' => [], // <----- 
       'doctrine_commented_types' => [], 
      ], 
     ], 
    ], 
]; 
+0

+1 https://github.com/DASPRiD/container-interop-doctrine我們使用它,而像它很多。 DASPRiD是一位可靠的架構師和一致的維護者。 – dualmon

2

首先,你必須創建一個擴展學說DBAL類型的自定義類型:

<?php 
use Doctrine\DBAL\Types\Type; 
use Doctrine\DBAL\Platforms\AbstractPlatform; 
use Doctrine\DBAL\Types\ConversionException; 

class MyType extends Type 
{ 
    const MYTYPE = 'mytype'; 

    public function getSQLDeclaration(array $fieldDeclaration, AbstractPlatform $platform) { 
     return 'mytype'; 
    } 

    public function convertToPHPValue($value, AbstractPlatform $platform) { 
     // convert your type to php value 
    } 

    public function convertToDatabaseValue($value, AbstractPlatform $platform) { 
     // convert your type to database value 
    } 
} 

最近我集成的值對象作爲學說的類型,所以像你可以看看你的新類型應該是什麼樣子:PostcodeType

下一步是註冊新的類型,讓你的學說引導或EntityManagerFactory的說:

<?php // ./src/Container/EntityManagerFactory.php 

if (!\Doctrine\DBAL\Types\Type::hasType("mytype")) { 
    \Doctrine\DBAL\Types\Type::addType('mytype', 'Your\Namespace\MyType'); 
    $em->getConnection()->getDatabasePlatform()->registerDoctrineTypeMapping('mytype', 'mytype'); 
} 

return $em; 

最後你已經註冊你的新類型,你可以使用它:

/** 
* @var \Your\Namespace\MyType 
* @Column(type="mytype") 
*/ 
protected $param;