7

所以我正在尝试将SearchVectorField添加到 Django 中的模型中:

class JobPosting(models.Model):
    ...
    ...
    search_vector = SearchVectorField()

我知道它应该是nullable或具有能够迁移的默认值,因此我删除了表中的所有条目以防止出现此问题。

但是,运行时出现以下错误makemigrations

You are trying to add a non-`nullable` field 'search_vector' to jobposting without a default;
we can't do that (the database needs something to populate existing rows).
Please select a fix:
   1) Provide a one-off default now
      (will be set on all existing rows with a null value for this column)
   2) Quit, and let me add a default in models.py
Select an option:

如果桌子是空的,为什么会这样说?我不想使列可以为空,如果可以避免,我宁愿没有默认值。

我的问题是,有什么办法可以强制makemigrationsmigrate因为如果桌子是空的,我不明白这个问题。我还有其他表,其中包含我不想删除的数据,因此无法删除数据库中的所有信息。

或者,如果选项1)是解决方案,我将如何格式化此类字段的默认值?我认为这不是普通的文本字段?

谢谢你的帮助。

4

2 回答 2

11

我不完全确定你为什么不想有一个默认值,但我会假设这是给定的。

我的问题是,是否有任何方法可以强制进行迁移和迁移,因为如果表为空,我不明白问题所在。

当前的数据库表可能是空的,但迁移应该可以在其他数据库实例上重复。因此 Django 不能假设在任何其他数据库上也一样。

一种解决方法可能是定义一个迁移,将字段创建为可为空,索引所有条目,然后将其更新为不可为空。

# -*- coding: utf-8 -*-
from __future__ import unicode_literals

from django.contrib.postgres.search import SearchVector, SearchVectorField      
from django.db import migrations


def index_entries(apps, schema_editor):
    Entry = apps.get_model("mymodel", "Entry")
    Entry.objects.update(search_vector=SearchVector('body_text'))


class Migration(migrations.Migration):

    dependencies = [
        ('mymodel', '0001_initial'),
    ]

    operations = [
        migrations.AddField(
            model_name='entry',
            name='search_vector',
            field=SearchVectorField(null=True),
        ),

        migrations.RunPython(index_entries),

        migrations.AlterField(
            model_name='entry',
            name='search_vector',
            field=SearchVectorField(null=False),
        ),
    ]
于 2017-06-23T20:26:18.677 回答
2

我只是使该字段可为空(并且可能不可编辑,因为您不会在管理界面或通过表单更改它):

class JobPosting(models.Model):
    ...
    ...
    search_vector = SearchVectorField(null=True, editable=False)

迁移不会有任何问题。

稍后您可以使该字段不可为空,但没有真正的理由这样做,因为无论如何您都会以编程方式对其进行更新。

于 2018-01-14T11:11:21.470 回答