当您首次使用新应用程序且表尚未添加到数据库时,South允许您创建迁移,以及为数据库中已有表的旧版应用程序创建迁移。关键是要知道何时该做什么。
您的第一个错误是删除迁移文件后立即删除,然后运行syncdb,Django不知道您想再由南方来管理该应用程序,因此它为您创建了表。当您创建最初的迁移然后进行迁移时,South试图创建django已经创建的表,因此会出现错误。
此时,您有两个选择。
从数据库中删除Wall应用程序的表,然后运行。
$ py manage.py migrate wall
这将运行迁移并创建表。伪造初始迁移运行
$ py manage.py migrate wall 0001 --fake
这将告诉South您已经在数据库中拥有表,因此只需对其进行伪造即可,这将在south_migrationhistory表中添加一行,以便下次运行迁移时它将知道第一次迁移已经运行了。
- 创建你的数据库
- 向南添加已安装的应用程序
- 运行syncdb,这会将django和south表添加到数据库中
- 添加您的应用
- 对于每个运行的应用程序,
python manage.py schemamigration app_name --initial
这将为您的应用程序创建初始迁移文件 - 然后运行向南迁移,
python manage.py migrate app_name
这会将表添加到数据库中。
- 向南添加已安装的应用程序
- 运行syncdb,这会将南表添加到数据库中
- 为您运行的每个应用程序
python manage.py schemamigration app_name --initial
创建初始迁移 - 对于您运行的每个应用程序
python manage.py migrate app_name 0001 --fake
,这都会伪造南方,它不会对那些模型的数据库做任何事情,只会将记录添加到south_migrationhistory表中,以便下次您要创建迁移时,您就可以了组。
- 创建数据库
- 向南添加已安装的应用程序
- 为您运行的每个应用程序
python manage.py schemamigration app_name --initial
创建初始迁移 - 运行syncdb,这会将所有未迁移的应用添加到数据库中。
- 然后进行向南迁移,
python manage.py migrate
这将为您的应用程序运行所有迁移。
现在,您已经设置了south,可以开始使用south来管理对这些应用程序的模型更改。运行的最常见命令是
python manage.pyschemamigration app_name migration_name--auto查看您上一次运行的迁移,它将查找更改并为您构建一个迁移文件。然后,您只需要运行即可
python manage.pymigrate为您更改数据库。
希望能有所帮助。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)