Django manage.py migration ValidationError

拉西克

当我使用django时,我python manage.py migrate在执行后遇到以下错误python manage.py makemigrations

File "manage.py", line 22, in <module>
    execute_from_command_line(sys.argv)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/core/management/__init__.py", line 381, in execute_from_command_line
    utility.execute()
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/core/management/__init__.py", line 375, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/core/management/base.py", line 323, in run_from_argv
    self.execute(*args, **cmd_options)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/core/management/base.py", line 364, in execute
    output = self.handle(*args, **options)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/core/management/base.py", line 83, in wrapped
    res = handle_func(*args, **kwargs)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/core/management/commands/migrate.py", line 234, in handle
    fake_initial=fake_initial,
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/migrations/executor.py", line 117, in migrate
    state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/migrations/executor.py", line 147, in _migrate_all_forwards
    state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/migrations/executor.py", line 245, in apply_migration
    state = migration.apply(state, schema_editor)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/migrations/migration.py", line 124, in apply
    operation.database_forwards(self.app_label, schema_editor, old_state, project_state)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/migrations/operations/fields.py", line 112, in database_forwards
    field,
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/backends/base/schema.py", line 433, in add_field
    definition, params = self.column_sql(model, field, include_default=True)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/backends/base/schema.py", line 161, in column_sql
    default_value = self.effective_default(field)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/backends/base/schema.py", line 233, in effective_default
    return field.get_db_prep_save(self._effective_default(field), self.connection)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/models/fields/__init__.py", line 789, in get_db_prep_save
    return self.get_db_prep_value(value, connection=connection, prepared=False)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/models/fields/__init__.py", line 1429, in get_db_prep_value
    value = self.get_prep_value(value)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/models/fields/__init__.py", line 1408, in get_prep_value
    value = super().get_prep_value(value)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/models/fields/__init__.py", line 1268, in get_prep_value
    return self.to_python(value)
  File "/Users/rasikraj/Desktop/eb-virt/lib/python3.7/site-packages/django/db/models/fields/__init__.py", line 1393, in to_python
    params={'value': value},
django.core.exceptions.ValidationError: ["'' value has an invalid format. It must be in YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format."]

什么可能是导致此错误的原因,以及如何解决此问题。我正在使用python 3.7和Django 2.2

威廉·范昂塞姆

基于该错误,存在一个DateTimeField[Django-doc]和一个default=''[Django-doc]但这不是一个有效的默认值:aDateTimeField应该已经在数据库中存储了一个日期时间(或者None如果该字段是NULL-able的话)。

因此,您应该为此提供有效的默认值DateTimeField,例如:

from django.utils import timezone

class SomeModel(models.Model):
    my_field = DateTimeField(default=timezone.now)

或者,您可以省略默认值,然后运行makemigrations在这种情况下,Django将询问您是否要提供一次性的默认值,该默认值将应用于数据库中已有的记录。

更改字段后,您需要删除在添加(或更改)该字段时构建的(无效)迁移文件,并使用进行新的迁移manage.py makemigrations毕竟,在构造迁移文件时不会进行此验证,现在您进行迁移确实会出错。如果您以后更改模型,仍然不会执行无效的迁移填充,因此它将再次引发相同的错误。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

Django manage.py migration ImportError

Django的:python manage.py migration --noinput

python manage.py migration Django错误

django命令'py manage.py runserver / makemigrations / migration'不能按预期工作

运行manage.py测试时Django数据迁移失败,但运行manage.py migration时失败

Django:python manage.py migration根本不执行任何操作

django:“ python manage.py migration”需要几个小时(以及其他奇怪的行为)

IBM Cloud db2 Django迁移python manage.py migration

Django-关系“关系”不存在。无法运行python manage.py migration?

python无法打开文件“ manage.py”-“ heroku运行python manage.py migration命令输入”

如何使docker build运行python manage.py migration

Django的manage.py显示旧命令

Django manage.py runserver无效语法

Django python manage.py syncdb

Django manage.py迁移错误

Django 环境 pyhon manage.py runserver

Django:manage.py工作正常,但django-admin失败

Django:./ manage.py [...]和python manage.py [...]有什么区别

python manage.py migration出现问题->没有名为psycopg2的模块

“ $ python manage.py db migration”使flask-migrate中的“选项值必须是字符串”

使用MySQL数据库运行“ python manage.py migration”时遇到SQL错误

python manage.py migration不会在postgres数据库中进行任何更改

python manage.py migration [向数据库添加新模型]

django不显示ValidationError

pytest-django为什么无法找到manage.py?

如何使用 Docker Compose 访问 Django manage.py

django-admin startproject不会创建manage.py

Django 无法运行 manage.py runserver 如何解决?

可以在Django中运行manage.py runserver