尝试生成迁移文件时出错

时间:2015-07-11 21:33:50

标签: php git symfony doctrine-orm doctrine-migrations

我目前正在开发一个Symfony项目,代码在git个回购中。 我们在一个故事/一个分支的基础上工作,在我们进行代码审查之前不要推送代码。

在询问之前,我想说一个有效的解决方案(已经在本地尝试过)将其中一个分支合并到我目前正在工作的分支中,但由于流程的原因我不能这样做。

所以,话虽如此,这是我的问题:

在一个分支中,我以这种方式配置了我的学说数据库:

doctrine:
    dbal:
        default_connection: default
        types:
            point: Phil\GeolocationBundle\ORM\PointType
        connections:
            default:
                driver:   "%database_driver%"
                host:     "%database_host%"
                port:     "%database_port%"
                dbname:   "%database_name%"
                user:     "%database_user%"
                password: "%database_password%"
                charset:  UTF8
                mapping_types: { point: point }
    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        auto_mapping: true
        dql:
            numeric_functions:
                POINTSTR: Phil\GeolocationBundle\ORM\PointStr
                DISTANCE: Phil\GeolocationBundle\ORM\Distance

phil_geolocation:
    default:
        latitude: 40.7388655
        longitude: -73.9830327
        city: New York

这很好用,如果我尝试生成一个迁移文件,它就会毫无问题地生成。

doctrine:
    dbal:
        driver:   "%database_driver%"
        host:     "%database_host%"
        port:     "%database_port%"
        dbname:   "%database_name%"
        user:     "%database_user%"
        password: "%database_password%"
        charset:  UTF8
        # if using pdo_sqlite as your database driver:
        #   1. add the path in parameters.yml
        #     e.g. database_path: "%kernel.root_dir%/data/data.db3"
        #   2. Uncomment database_path in parameters.yml.dist
        #   3. Uncomment next line:
        #     path:     "%database_path%"

    orm:
        auto_generate_proxy_classes: "%kernel.debug%"
        auto_mapping: true

当我尝试在此分支中生成迁移时,出现以下错误:

[Doctrine\DBAL\DBALException]                                                                     
  Unknown database type point requested, Doctrine\DBAL\Platforms\MySqlPlatform may not support it.  

奇怪的事实是,在我在另一个分支机构工作之后,这开始发生了,正如我在开头所说,如果我将工作分支合并到非工作分支中,则生成迁移文件。

我尝试了清除symfony缓存(dev和prod环境,以防万一)等明显的事情,更新了作曲家文件(因为第一个配置是由我需要使用的组件添加的,所以在我的第二个分支中它被删除了) ,检查其他配置文件,如config-dev.yml等,只是为了仔细检查我没有遗漏一些东西。我甚至很难删除我的缓存目录。

我对可能发生的事情没有想法,就好像是以某种方式缓存我的配置文件,但它应该是不可能的!

我发现了this帖子,但这不是我发生的事情。

1 个答案:

答案 0 :(得分:2)

您是否在从一个分支转移到另一个分支之前运行doctrine:migrations:execute —down yourmigrationnumber

您的数据库处于不同的状态(来自另一个分支),因此如果您在不执行down()方法的情况下运行新的迁移,它将尝试创建一个迁移文件,之前使用该类型删除旧状态不知道如何处理它。

如果有帮助,请告诉我!