4

我在 Django 南迁移时遇到了麻烦。这可能与我们如何布置项目有关,但它以前可以正常工作,并且在本地运行良好。

我昨晚推送了包含my_app应用程序迁移的新代码。所以在我当地的环境中......

$ ./manage.py migrate --list
socialaccount
(*) 0001_initial
(*) 0002_genericmodels
(*) 0003_auto__add_unique_socialaccount_uid_provider
(*) 0004_add_sites
(*) 0005_set_sites
(*) 0006_auto__del_field_socialapp_site
(*) 0007_auto__add_field_socialapp_client_id
(*) 0008_client_id
(*) 0009_auto__add_field_socialtoken_expires_at
(*) 0010_auto__chg_field_socialtoken_token
(*) 0011_auto__chg_field_socialtoken_token
payments
(*) 0001_initial
users
(*) 0001_initial
my_app
(*) 0001_initial
(*) 0002_auto__add_organizerapplication

在 heroku 中,它不会将 my_app 识别为具有迁移功能的应用程序。当我尝试迁移该应用程序时......

$ heroku run my_app/manage.py migrate my_app --app=my_app

Running my_app/manage.py migrate my_app attached to terminal... up, run.5016
The app 'my_app' does not appear to use migrations.
./manage.py migrate [appname] [migrationname|zero] [--all] [--list] [--skip] [--merge] [--no-initial-data] [--fake] [--db-dry-run] [--database=dbalias]

如果我列出迁移,您会注意到 my_app 未列出...

$ heroku run my_app/manage.py migrate --list --app=my_app

Running my_app/manage.py migrate --list attached to terminal... up, run.8264

socialaccount
(*) 0001_initial
(*) 0002_genericmodels
(*) 0003_auto__add_unique_socialaccount_uid_provider
(*) 0004_add_sites
(*) 0005_set_sites
(*) 0006_auto__del_field_socialapp_site
(*) 0007_auto__add_field_socialapp_client_id
(*) 0008_client_id
(*) 0009_auto__add_field_socialtoken_expires_at
(*) 0010_auto__chg_field_socialtoken_token
(*) 0011_auto__chg_field_socialtoken_token
payments
(*) 0001_initial
users
(*) 0001_initial

我不确定它是否相关,但在我检查时my_app会在我的列表中列出。INSTALLED_APPS

更新

问题是这个特定的迁移目录丢失了__init__.py.像通过 Heroku 这样的运行命令convert_to_south不会影响这一点,因为本地文件更改不会持续。使用该文件再次推送 repo 可以识别迁移。然后我只需要伪造第一次迁移,我就很好。

4

1 回答 1

4

确保在要迁移的应用程序的迁移文件夹中有一个 init.py 文件。South 将在本地工作,但不会在 heroku 上进行生产。只需从您的一个应用程序中复制一个 init.py 文件,并将其放入您收到错误的应用程序的迁移文件夹中。将该更改推送到生产环境,然后迁移。

于 2014-06-03T14:41:46.147 回答