gpt4 book ai didi

doctrine-orm - 如何使用 Symfony 2 在 Doctrine 2 中添加 BLOB 类型

转载 作者:行者123 更新时间:2023-12-01 22:43:20 28 4
gpt4 key购买 nike

在 Symfony 2 中,我生成了一个 Bundle,用于将任何类型的文档存储到数据库中,但我需要 BLOB 列类型。

发送至this question我将 BlobType 类添加到 Doctrine DBAL 中,但为了使用新的列类型,我必须更改

Doctrine\DBAL\Types\Type

[...]

const BLOB = 'blob';

[...]

private static $_typesMap = array(
[...],
self::BLOB => 'Doctrine\DBAL\Types\BlobType',
);

Doctrine\DBAL\Platforms\MySqlPlatform(如果我更改了 Doctrine\DBAL\Platforms\AbstractPlatform 可能会更好)

[...]
protected function initializeDoctrineTypeMappings()
{
$this->doctrineTypeMapping = array(
[...],
'blob' => 'blob',
);
}

[...]

/**
* Obtain DBMS specific SQL to be used to create time fields in statements
* like CREATE TABLE.
*
* @param array $fieldDeclaration
* @return string
*/
public function getBlobTypeDeclarationSQL(array $fieldDeclaration)
{
return 'BLOB';
}

现在我没有太多时间用于“漂亮的解决方案”,但将来我想恢复 Doctrine 类并能够将新的列类型分配到 Symfony 2 Bootstrap 中。我想我应该编辑我的 app/bootstrap.php.cache 但我不知道如何干预。

最佳答案

这对我有用:

  1. 创建您的 blobtype(参见 https://gist.github.com/525030/38a0dd6a70e58f39e964ec53c746457dd37a5f58)

  2. 将此添加到您的 Bundle 初始化 (/src/YOURDOMAIN/YOURBUNDLE/YOURDOMAINYOUBUNDLE.php)

    class YourBundle extends Bundle
    {
    public function boot()
    {
    $em = $this->container->get('doctrine.orm.entity_manager');
    Type::addType('blob', 'YOURDOMAIN\YOURBUNDLE\YOURTYPEDIRECTORY\BlobType');
    $em->getConnection()->getDatabasePlatform()->registerDoctrineTypeMapping('blob','blob');
    }
    }

关于doctrine-orm - 如何使用 Symfony 2 在 Doctrine 2 中添加 BLOB 类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7738767/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com