Django                
            Routery baz danych
        
        
            
    Szukaj…
Dodanie pliku routingu bazy danych
 Aby korzystać z wielu baz danych w Django, po prostu określ każdą z nich w settings.py : 
DATABASES = {
    'default': {
        'NAME': 'app_data',
        'ENGINE': 'django.db.backends.postgresql',
        'USER': 'django_db_user',
        'PASSWORD': os.environ['LOCAL_DB_PASSWORD']
    },
    'users': {
        'NAME': 'remote_data',
        'ENGINE': 'django.db.backends.mysql',
        'HOST': 'remote.host.db',
        'USER': 'remote_user',
        'PASSWORD': os.environ['REMOTE_DB_PASSWORD']
    }
}
 Użyj pliku dbrouters.py , aby określić, które modele powinny działać na których bazach danych dla każdej klasy operacji bazy danych, np. W przypadku danych zdalnych przechowywanych w danych remote_data , możesz chcieć: 
class DbRouter(object):
    """
    A router to control all database operations on models in the
    auth application.
    """
    def db_for_read(self, model, **hints):
        """
        Attempts to read remote models go to remote database.
        """
        if model._meta.app_label == 'remote':
            return 'remote_data'
        return 'app_data'
    def db_for_write(self, model, **hints):
        """
        Attempts to write remote models go to the remote database.
        """
        if model._meta.app_label == 'remote':
            return 'remote_data'
        return 'app_data'
    def allow_relation(self, obj1, obj2, **hints):
        """
        Do not allow relations involving the remote database
        """
        if obj1._meta.app_label == 'remote' or \
           obj2._meta.app_label == 'remote':
           return False
        return None
    def allow_migrate(self, db, app_label, model_name=None, **hints):
        """
        Do not allow migrations on the remote database
        """
        if model._meta.app_label == 'remote':
            return False
        return True
 Na koniec dodaj dbrouter.py do settings.py : 
DATABASE_ROUTERS = ['path.to.DbRouter', ]
Określanie różnych baz danych w kodzie
 Normalna obj.save() użyje domyślnej bazy danych lub, jeśli używany jest router bazy danych, użyje bazy danych określonej w db_for_write . Możesz to zmienić, używając: 
obj.save(using='other_db')
obj.delete(using='other_db')
Podobnie do czytania:
MyModel.objects.using('other_db').all()
Modified text is an extract of the original Stack Overflow Documentation
        Licencjonowany na podstawie CC BY-SA 3.0
        Nie związany z Stack Overflow