标签: django-south

在django字段中添加"直通"表并与南方迁移?

看起来这应该是"容易"或至少在某处记录,我只是无法找到它.

让我们说我有一个模型:

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 django-south

14
推荐指数
2
解决办法
2693
查看次数

找不到名为"X"的夹具

我正在使用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它工作正常.关于如何解决这个问题的任何想法?

django django-south

14
推荐指数
1
解决办法
7525
查看次数

如何用South重命名外键字段?

重命名一个简单的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)

这源于迁移试图由于某种原因向后运行(如跟踪中所示).

有任何想法吗?

django django-south

13
推荐指数
4
解决办法
5415
查看次数

将South添加到Django项目,开发和生产

将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 - 它是不是在南方做任何不同的事情?

migration django django-south

13
推荐指数
2
解决办法
3767
查看次数

Django-South内省规则不起作用

我正在使用Django 1.2.3South 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)

python migration django django-south

13
推荐指数
1
解决办法
4127
查看次数

Eclipse中的PyDev无法识别来自South的db.add_column

我刚刚安装了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解释器更快乐的任何提示?

eclipse django pydev django-south

13
推荐指数
2
解决办法
1141
查看次数

Django South初始迁移错误

我有一个新的Django 1.3项目和我创建的应用程序.我向南添加了我settings.py还没有跑syncdb.当我按照南方教程和文档执行以下命令时,我收到了如下所示的错误.

  • 有关导致问题的原因的任何想法?更新:未正确安装South(请参阅答案).
  • South 0.7.3与Django 1.3兼容吗?更新:是的.

执行的命令和南错误

$ 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)

migration django django-south

13
推荐指数
1
解决办法
1万
查看次数

如何在django中禁用南调试日志记录?

当我在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)

并且通过所有这些日志记录输出,相关的错误消息在垃圾海中丢失.有没有办法禁用这个输出?

testing django debugging django-south

13
推荐指数
2
解决办法
2898
查看次数

南迁:DatabaseOperations没有属性'shorten_name'

我有一个模型,我设法在两台不同的计算机上迁移没有问题.但是在我的服务器上我收到以下错误:

迁移错误: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 postgresql data-migration django-south

13
推荐指数
1
解决办法
1645
查看次数

您的数据库django没有南数据库模块'south.db.postgresql_psycopg2'

我有一个版本的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 postgresql psycopg2 django-south

13
推荐指数
2
解决办法
1万
查看次数