在 Symfony 6 中,如果你尝试使用 binary
类型来映射一个二进制字段,你会发现无法使用 Doctrine 来对该字段进行读取和写入,因为它会将该字段映射为一个字符串类型。
为了解决这个问题,我们可以添加一个自定义类型,让 Doctrine 知道如何将该字段映射为二进制类型。
首先,创建一个新类 BinaryType
,并将其扩展为 Doctrine\DBAL\Types\Type
,这样它就可以被注册到 Doctrine 类型中。然后,在 BinaryType
类中,我们需要实现 getSQLDeclaration()
方法,该方法用于返回我们希望在数据库中使用的 SQL 类型。在本例中,我们将使用 BINARY(16)
。最后,我们需要定义一个名称以及我们将在 Doctrine 类型中使用的名称,这里我们使用 binary
。
示例代码:
namespace App\Doctrine\Type;
use Doctrine\DBAL\Types\Type;
use Doctrine\DBAL\Platforms\AbstractPlatform;
class BinaryType extends Type
{
public function getSQLDeclaration(array $fieldDeclaration, AbstractPlatform $platform)
{
return $platform->getBinaryTypeDeclarationSQL(array_merge([
'length' => 16
], $fieldDeclaration));
}
public function getName()
{
return 'binary';
}
}
然后,我们需要在我们的 Doctrine 配置文件中注册该类型:
# config/packages/doctrine.yaml
doctrine:
dbal:
types:
binary: App\Doctrine\Type\BinaryType
现在,我们可以在实体中使用 binary
类型了:
/**
* @ORM\Column(type="binary")
*/
private $hash;
注意,我们并没有指定具体的长度,因为我们默认是使用 BINARY(16)
的长度。
现在,我们可以使用 Doctrine 对二进制字段进行读写操作了。