看起来这应该是"容易"或至少在某处记录,我只是无法找到它.
让我们说我有一个模型:
class A(models.Model):
users = models.ManyToMany('auth.User', blank=True)
Run Code Online (Sandbox Code Playgroud)
现在我想迁移到一个through表来向ManyToMany关系添加字段...
class AUsers(models.Model):
user = models.ForeignKey('auth.User')
a = models.ForeignKey('A')
new_field = models.BooleanField()
class A(models.Model):
users = models.ManyToMany('auth.User', blank=True, through='AUsers')
Run Code Online (Sandbox Code Playgroud)
然后我做:
% ./manage.py schemamigration app --auto
Run Code Online (Sandbox Code Playgroud)
并不奇怪,它告诉我它将通过表删除原始的自动创建并为其创建一个新的AUsers.目前最好的做法是什么?是否有适当的方式迁移到新through表?我db_table在Meta 使用吗?我是不是through=...马上使用...然后做一个schemamigration --auto,然后a datamigration复制当前表(不知何故,不确定...)然后添加through关系,让它杀死表?
这里的诀窍是什么?这真的很难吗?
我正在使用Django 1.6,我使用South来处理迁移.在我的大多数应用程序中,我曾经有过initial_data.json文件.我将它们转换为加载迁移而不是Django自动加载(因为这在文档中是推荐的)
当我遇到一个奇怪的行为/错误,根据模型代码而不是迁移状态完成加载装置时,我使用的是南方版本0.8.2.我看到最新版本(0.8.4)已经添加了一些相关的bug修复loaddata,所以我升级到它.
现在我在加载夹具的所有迁移中收到以下错误:
UserWarning: No fixture named 'X' found.
Run Code Online (Sandbox Code Playgroud)
当我使用Django时loaddata它工作正常.关于如何解决这个问题的任何想法?
重命名一个简单的charfield等似乎很容易(Django - 如何使用South重命名模型字段?)
但是,当我尝试在ForeignKey字段上使用相同的时候,我收到一个错误:
_mysql_exceptions.OperationalError: (1091, "Can't DROP '[new_fkey_field_name]'; check that column/key exists")
Run Code Online (Sandbox Code Playgroud)
这源于迁移试图由于某种原因向后运行(如跟踪中所示).
有任何想法吗?
将South添加到现有的Django项目中.我把它安装在开发机器和"生产"服务器上.
我在开发机器上完成了以下操作,然后:将南方应用程序添加到settings.py,
python manage.py syncdb
python manage.py convert_to_south myproject.myapp
Run Code Online (Sandbox Code Playgroud)
然后改变了一些模型
python manage.py schemamigration myproject.myapp --auto
python manage.py migrate myproject.myapp
Run Code Online (Sandbox Code Playgroud)
到目前为止似乎工作.我现在不太确定的是在生产服务器上做什么.只需手动重复所有这些步骤?上传修改后的settings.py,执行syncdb,convert_to_south,上传修改过的models.py,做schemamigration,迁移?有些不同?这里的教程说明了如何将迁移添加到版本控制中,因此,大概应该将它们上传并以某种方式应用于生产服务器上?
此外,现在我在开发机器上使用sqlite3,在服务器上使用mysql - 它是不是在南方做任何不同的事情?
我正在使用Django 1.2.3和South 0.7.3.
我正在尝试将我的应用程序(命名core)转换为使用Django-South.我有一个我正在使用的自定义模型/字段,名称ImageWithThumbsField.它基本上只是django.db.models.ImageField具有一些属性,如身高,体重等.
虽然./manage.py convert_to_auth core我试图接受南方的冰冻错误.我不明白为什么,我可能会遗漏一些东西......
我使用的是简单的自定义模型:
from django.db.models import ImageField
class ImageWithThumbsField(ImageField):
def __init__(self, verbose_name=None, name=None, width_field=None, height_field=None, sizes=None, **kwargs):
self.verbose_name=verbose_name
self.name=name
self.width_field=width_field
self.height_field=height_field
self.sizes = sizes
super(ImageField, self).__init__(**kwargs)
Run Code Online (Sandbox Code Playgroud)
这是我的内省规则,我将其添加到我的顶部models.py:
from south.modelsinspector import add_introspection_rules
from lib.thumbs import ImageWithThumbsField
add_introspection_rules(
[
(
(ImageWithThumbsField, ),
[],
{
"verbose_name": ["verbose_name", {"default": None}],
"name": ["name", {"default": None}],
"width_field": ["width_field", {"default": None}],
"height_field": ["height_field", {"default": …Run Code Online (Sandbox Code Playgroud) 我刚刚安装了South(0.7.3,python-2.6)并使用python解释器成功完成了教程.这意味着我能够创建一个模型并在没有任何错误的情况下进行迁移,因此South似乎在python shell中运行良好.我在教程中使用了sqlite3 db.
但是,当我在Eclipse中打开项目时,Eclipse无法识别迁移文件夹中与db关联的功能:0001_initial.py和0002_auto__add_field_knight_dances_whenever_able.py文件.我得到了具体的错误(导入的未定义变量:add_column,create_table,delete_column,delete_table,send_create_signal)
直到南方安装,Eclipse一直在创建django应用程序.我确实将PyDev解释器指向了site-packages下的南文件夹(C:\ python26\Lib\site-packages\south-0.7.3-py2.6.egg)(其他库,如Django和django-picklefield工作)精细.)
我从eclipse项目和python shell运行了一个简单的脚本,两者似乎都有相同的sys.path
有关让Eclipse python解释器更快乐的任何提示?
我有一个新的Django 1.3项目和我创建的应用程序.我向南添加了我settings.py还没有跑syncdb.当我按照南方教程和文档执行以下命令时,我收到了如下所示的错误.
$ python ./manage.py schemamigration qexpenses --initial
Creating migrations directory at '/Users/matthew/development/quest-projects/qexpense-tracker/quexptrkr/../quexptrkr/qexpenses/migrations'...
Creating __init__.py in '/Users/matthew/development/quest-projects/qexpense-tracker/quexptrkr/../quexptrkr/qexpenses/migrations'...
+ Added model qexpenses.Buyer
+ Added model qexpenses.Vendor
+ Added model qexpenses.Department
+ Added model qexpenses.Project
+ Added model qexpenses.PurchaseType
+ Added model qexpenses.PurchaseOrder
Created 0001_initial.py. You can now apply this migration with: ./manage.py migrate qexpenses
(qexpense-tracker)matthew@Matthew-Rankins-MacBook-Pro:~/development/quest-projects/qexpense-tracker/quexptrkr
$ python ./manage.py migrate
Traceback (most recent call last):
File "./manage.py", line 14, …Run Code Online (Sandbox Code Playgroud) 当我在Django中运行我的测试时,失败后我从南方获得了几页调试输出,如下所示:
south: DEBUG: south execute "CREATE INDEX "sometable_4d5bad5" ON "video_playable" ("network_id");" with params "[]"
south: DEBUG: south execute "CREATE INDEX "sometable_790e6d98" ON "video_playable" ("published");" with params "[]"
south: DEBUG: south execute "CREATE INDEX "sometable_72312277" ON "video_playable" ("archived");" with params "[]"
Run Code Online (Sandbox Code Playgroud)
并且通过所有这些日志记录输出,相关的错误消息在垃圾海中丢失.有没有办法禁用这个输出?
我有一个模型,我设法在两台不同的计算机上迁移没有问题.但是在我的服务器上我收到以下错误:
迁移错误:some_app:0002_auto__some_migration
AttributeError:'DatabaseOperations'对象没有属性'shorten_name'
检查迁移文件我看到一行:
m2m_table_name = db.shorten_name(u'some_app_some_class_some_attribute')
Run Code Online (Sandbox Code Playgroud)
这可能是罪魁祸首.(有几行使用它shorten_name.我不知道如何解决这个问题.
我的服务器上的虚拟环境有南0.7.6,Django 1.5(以及Postgis启用的postgres)
我有一个版本的django应用程序1.6.5,我正在尝试将其升级到1.8,但是在django版本增加到之后我就得到了以下错误1.8
There is no South database module 'south.db.postgresql_psycopg2' for your database. Please either choose a supported database, check for SOUTH_DATABASE_ADAPTER[S] settings, or remove South from INSTALLED_APPS.
Run Code Online (Sandbox Code Playgroud)
码
INSTALLED_APPS = [
'django_messages',
'avatar',
'tinymce',
'south',
'tracking',
......
]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'HOST': '127.0.0.1',
'NAME': 'xxxxxx',
'USER': 'xxxxxx',
'PASSWORD': 'xxxxxx',
},
}
Run Code Online (Sandbox Code Playgroud)
那么问题是什么以及需要做些什么才能解决这个问题呢?
我甚至尝试使用以下设置并在运行django本地服务器时收到相同的错误
SOUTH_DATABASE_ADAPTERS = {
'default': "south.db. postgresql_psycopg2"
}
Run Code Online (Sandbox Code Playgroud) django ×10
django-south ×10
migration ×3
postgresql ×2
debugging ×1
eclipse ×1
psycopg2 ×1
pydev ×1
python ×1
testing ×1