我目前正在开发一个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帖子,但这不是我发生的事情。
答案 0 :(得分:2)
您是否在从一个分支转移到另一个分支之前运行doctrine:migrations:execute —down yourmigrationnumber
?
您的数据库处于不同的状态(来自另一个分支),因此如果您在不执行down()
方法的情况下运行新的迁移,它将尝试创建一个迁移文件,之前使用该类型删除旧状态不知道如何处理它。
如果有帮助,请告诉我!