【问题标题】:"relation "social_auth_code" does not exist" when applying migrations on django在 django 上应用迁移时,“关系“social_auth_code”不存在”
【发布时间】:2016-03-17 05:43:35
【问题描述】:

我最近从 django-social-auth 切换到 python-social-auth,但它显然损坏了我的迁移系统。每当我尝试迁移更改时,我都会得到这个:

  File "manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/__init__.py", line 385, in execute_from_command_line
    utility.execute()
  File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/__init__.py", line 377, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/base.py", line 288, in run_from_argv
    self.execute(*args, **options.__dict__)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/base.py", line 338, in execute
    output = self.handle(*args, **options)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/core/management/commands/migrate.py", line 161, in handle
    executor.migrate(targets, plan, fake=options.get("fake", False))
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/executor.py", line 68, in migrate
    self.apply_migration(migration, fake=fake)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/executor.py", line 102, in apply_migration
    migration.apply(project_state, schema_editor)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/migration.py", line 108, in apply
    operation.database_forwards(self.app_label, schema_editor, project_state, new_state)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/migrations/operations/fields.py", line 139, in database_forwards
    schema_editor.alter_field(from_model, from_field, to_field)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/schema.py", line 457, in alter_field
    self._alter_field(model, old_field, new_field, old_type, new_type, old_db_params, new_db_params, strict)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/schema.py", line 603, in _alter_field
    params,
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/schema.py", line 103, in execute
    cursor.execute(sql, params)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/utils.py", line 65, in execute
    return self.cursor.execute(sql, params)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/utils.py", line 94, in __exit__
    six.reraise(dj_exc_type, dj_exc_value, traceback)
  File "/app/.heroku/python/lib/python2.7/site-packages/django/db/backends/utils.py", line 65, in execute
    return self.cursor.execute(sql, params)
django.db.utils.ProgrammingError: relation "social_auth_code" does not exist

问题在于它只发生在我的应用程序的生产版本中,并且由于某些其他原因,我过去不得不删除我的迁移文件。不便于调查。无论如何,它现在可以完美地与我的开发应用程序一起使用,但我无法弄清楚生产中可能出现的问题,我尝试了世界上所有的“伪造迁移”技巧,但似乎没有任何效果。

我在网络上唯一能找到这样一个错误的地方是there 但我从未使用过 South,所以第一个答案对我不起作用。 直接挖掘迁移表并发送原始 SQL 指令可能是解决方案,但由于它在我的生产版本中,我对修补数据库感到不舒服(我有成千上万的注册用户,那里有数据等等)。简而言之,我深陷其中 :)。还有就是不知道用哪个命令直接访问db中的迁移表...

任何保证我的数据安全的解决方案都非常受欢迎:))

【问题讨论】:

    标签: python sql django postgresql django-migrations


    【解决方案1】:

    迁移到 python_social_auth 时,我遇到了同样的错误。 这对 Django 1.8 很有用。 也许我的解决方案会对您有所帮助:

    1. python_social_auth 的假迁移首字母

      python manage.py migrate default 0001 --fake
      
    2. 为初始 psa 创建自己的迁移并将其放入 /your_project/your_app/migrations/0009_migrate_to_psa.py:

      # -*- coding: utf-8 -*-
      from __future__ import unicode_literals
      
      from django.db import models, migrations
      import social.apps.django_app.default.fields
      from django.conf import settings
      import social.storage.django_orm
      from social.utils import setting_name
      
      user_model = getattr(settings, setting_name('USER_MODEL'), None) or \
                   getattr(settings, 'AUTH_USER_MODEL', None) or \
                   'auth.User'
      
      
      class Migration(migrations.Migration):
      
          dependencies = [
              migrations.swappable_dependency(user_model),
              ('your_app', '0008_last_migration_in_your_app'),
              ('default', '0001_initial'),
          ]
      
          operations = [
              migrations.CreateModel(
                  name='Code',
                  fields=[
                      ('id', models.AutoField(
                          verbose_name='ID', serialize=False, auto_created=True,
                          primary_key=True)),
                      ('email', models.EmailField(max_length=75)),
                      ('code', models.CharField(max_length=32, db_index=True)),
                      ('verified', models.BooleanField(default=False)),
                  ],
                  options={
                      'db_table': 'social_auth_code',
                  },
                  bases=(models.Model, social.storage.django_orm.DjangoCodeMixin),
              ),
              migrations.AlterUniqueTogether(
                  name='code',
                  unique_together=set([('email', 'code')]),
              ),
          ]
      

      注意依赖关系:

      dependencies = [
          migrations.swappable_dependency(user_model),
          ('your_app', '0008_last_migration_in_your_app'),
          ('default', '0001_initial'),
      ]
      
    3. 迁移您的项目

      python manage.py migrate your_app
      
    4. 并全部迁移

      python manage.py migrate
      

    更新: 不幸的是,此方法需要您的应用程序文件 models.py 中的模型代码。否则下次操作 makemigrations 时该表将从数据库中删除。 /your_project/your_app/models.py:

    from social.storage.django_orm import DjangoCodeMixin
    class Code(models.Model, DjangoCodeMixin):
        email = models.EmailField(max_length=254)
        code = models.CharField(max_length=32, db_index=True)
        verified = models.BooleanField(default=False)
    
        class Meta:
            db_table = 'social_auth_code'
            unique_together = ('email', 'code')
    

    【讨论】:

    • 谢谢,我会试试的。关于依赖项('your_project','last_migration_in_your_project'),我应该把文件放在哪里,我应该把什么放在里面?
    • 我澄清了答案。如果您不执行此行 (('myapp', '0008_last_migration.py'),),那么当您运行 migrate myapp 时 Django 将失败:CommandError: Conflicting migrations detected (0009_migrate_psa, 0008_last_migration in your_app)。要修复它们,请运行'python manage.py makemigrations --merge'
    • 嗯...事实上,当我对模型进行任何进一步更改时,它一直要求我运行“makemigrations”,所以我这样做了,它创建了一个新的迁移文件,然后我再次迁移并重新提示我要运行“makemigrations”...
    【解决方案2】:

    我之前尝试过运行该解决方案,但在依赖方面遇到了一些困难。 我最终只是在迁移0007_code_timestamp 中将以下几行添加到Migration.operations 列表中(与原始first answer suggested 完全相同)

            migrations.CreateModel(                                                 
                name='Code',                                                        
                fields=[                                                            
                    ('id', models.AutoField(                                        
                        verbose_name='ID', serialize=False, auto_created=True,      
                        primary_key=True)),                                         
                    ('email', models.EmailField(max_length=75)),                    
                    ('code', models.CharField(max_length=32, db_index=True)),       
                    ('verified', models.BooleanField(default=False)),               
                ],                                                                  
                options={                                                           
                    'db_table': 'social_auth_code',                                 
                },                                                                  
                bases=(models.Model, social_django.storage.DjangoCodeMixin),        
            ),                                                                      
            migrations.AlterUniqueTogether(                                         
                name='code',                                                        
                unique_together=set([('email', 'code')]),                           
            ),       
    

    并确保import social_django 在顶部。

    这为我解决了这个问题,它比创建新的迁移和处理依赖关系更容易。

    【讨论】:

      猜你喜欢
      • 2017-07-01
      • 2019-02-04
      • 2017-03-25
      • 1970-01-01
      • 2021-07-07
      • 2016-08-15
      • 2018-04-07
      • 2016-02-06
      • 1970-01-01
      相关资源
      最近更新 更多