I am working on an application with two databases and two different
dbRouters.  On migrating a model with a OneToOneField I get the following
error :

django.db.utils.OperationalError: (1824, "Failed to open the referenced
table 'auth_user'")


The auth dbRouter is for the [auth, sessions, contenttypes, admin] apps
while the Redford dbRouter is for the main app.

Below is the code for the routers :


*auth dbRouter*


class AuthRouter:
    """
    A router to control all database operations on models in the
    auth and contenttypes applications.
    """
    route_app_labels = ('auth', 'contenttypes', 'sessions', 'admin')

    def db_for_read(self, model, **hints):
        """
        Attempts to read auth and contenttypes models go to auth_db.
        """
        if model._meta.app_label in self.route_app_labels:
            return "default"
        return False

    def db_for_write(self, model, **hints):
        """
        Attempts to write auth and contenttypes models go to auth_db.
        """
        if model._meta.app_label in self.route_app_labels:
            return "default"
        return False

    def allow_relation(self, obj1, obj2, **hints):
        """
        Allow relations if a model in the auth or contenttypes apps is
        involved.
        """

        if (obj1._meta.app_label in self.route_app_labels or
            obj2._meta.app_label == 'julia' or 'redford'
            ):
            return True
        return None

    def allow_migrate(self, db, app_label, model_name=None, **hints):
        """
        Make sure the auth and contenttypes apps only appear in the
        'auth_db' database.
        """


        if db == 'default':
            # Migrate Django core app models if current database is home
            if app_label in ('auth','admin','sessions','contenttypes'):
                return True

            else:
                return False

                # Non Django core app models should not be migrated if
database is home
        # Other database should not migrate Django core app models


        elif app_label in ['auth','admin','sessions','contenttypes']:
            return False
        # Otherwise no opinion, defer to other routers or default database
        return None



*Redford dbRouter*


class RedfordRouter(object):

    route_app_labels = ('auth', 'contenttypes', 'sessions', 'admin')

    def db_for_read(self, model, **hints):
        if model._meta.app_label == 'redford':
          return 'redford_db'
        return False

    def db_for_write(self, model, **hints):
        if model._meta.app_label == 'redford':
          return 'redford_db'
        return False

    def allow_relation(self, obj1, obj2, **hints):
        if obj1._meta.app_label == 'redford' or obj2._meta.app_label ==
'auth':
            return True
        return None

    def allow_migrate(self, db, app_label, model_name=None, **hints):

        if db == 'default' or app_label in self.route_app_labels:
            print(db, app_label)
            return None
        elif db == 'redford_db':
            if app_label == 'redford':
                return True
            return False
        return None


The code for the models is as below :


class Employer(models.Model):
     emp_Name = models.OneToOneField(User, on_delete=models.CASCADE,
 null=True)
     emp_Company = models.CharField(max_length=100)
     emp_Address = models.CharField(max_length=500)
     emp_Tel = models.CharField(max_length=100)
     emp_JobTitle = models.CharField(max_length=200, null=True)
     emp_JobDesc = models.CharField(max_length=600, null=False)

     def __str__(self):
         return self.emp_Name


Hope we can work it out


regards


[image: --]

Maninder Kumar
[image: http://]about.me/maninder.s.kumar
<http://about.me/maninder.s.kumar?promo=email_sig>

-- 
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to django-users+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-users/CABOHK3QsWztSogPx_RzbYcZ46WyK0cHV8JxXBuRSbr2epeQKhg%40mail.gmail.com.

Reply via email to