当我尝试使用学说“bin/console algorithm:schema:update -f”更新我的架构时遇到问题
问题是
<块引用>[Doctrine\DBAL\Exception]
请求了未知的列类型“Finances\Bank\Infrastructure\Persistence\Doctrine\BankIdType”。您使用的任何 Doctrine 类型都必须使用 \Doctrine\DBAL\Types\Type::addType() 进行注册。你可以得到一个列表
t 所有已知类型的 \Doctrine\DBAL\Types\Type::getTypesMap()。如果在数据库内省期间发生此错误,那么您可能忘记为 Doctrine 类型注册所有数据库类型。你
请参阅 AbstractPlatform#registerDoctrineTypeMapping() 或让您的自定义类型实现 Type#getMappedDatabaseTypes()。如果类型名称为空,则可能是缓存有问题或忘记了一些映射
信息。
这很奇怪,因为当我在我的模式数据库中看到我在评论中找到了类型,如果我删除它,我可以正常更新模式。我没有找到任何额外的配置来解决这个问题。 其实我的 config.yml 是:
doctrine:
dbal:
driver: "%database_driver%"
host: "%database_host%"
port: "%database_port%"
dbname: "%database_name%"
user: "%database_user%"
password: "%database_password%"
charset: UTF8
types:
bank_id: Finances\Bank\Infrastructure\Persistence\Doctrine\BankIdType
自定义类型:
final class BankIdType extends UuidType
{
protected function typeClassName(): string
{
return BankId::class;
}
}
UuidType(抽象)
abstract class UuidType extends StringType implements DoctrineCustomType
{
abstract protected function typeClassName(): string;
public function getName(): string
{
return self::customTypeName();
}
public static function customTypeName(): string
{
return static::class;
}
public function convertToPHPValue($value, AbstractPlatform $platform)
{
if(!is_null($value)){
$className = $this->typeClassName();
return new $className($value);
}else{
return $value;
}
}
/** @var Uuid $value */
public function convertToDatabaseValue($value, AbstractPlatform $platform)
{
if(!is_null($value)){
return $value;
}else{
return $value;
}
}
}
实现的接口:
interface DoctrineCustomType
{
public static function customTypeName(): string;
}
这是映射“Bank.orm.xml”
<?xml version="1.0" encoding="utf-8"?>
<doctrine-mapping xmlns="http://doctrine-
project.org/schemas/orm/doctrine-mapping"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://doctrine-project.org/schemas/orm/doctrine-mapping https://www.doctrine-project.org/schemas/orm/doctrine-mapping.xsd">
<entity name="Finances\Bank\Domain\Bank">
<id name="id" type="bank_id" column="id"/>
这让我发疯!
答案 0 :(得分:0)
最后的解决办法是删除mysql数据库中所有的学说注释,并在映射配置中设置自定义类型如下:
types:
bank_id:
class: Finances\Bank\Infrastructure\Persistence\Doctrine\BankIdType
commented: false