Как использовать несколько баз данных в одном приложении Django? [дубликат]
Я пытаюсь настроить мое приложение Django на использование нескольких баз данных в одном приложении.
Я определил различные базы данных в файле settings.py.
У меня только одно приложение polls
.
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'mypage',
'USER': 'root',
'PASSWORD': '',
'HOST': 'localhost',
'PORT': '3306',
},
'ringi_db':{
'ENGINE': 'django.db.backends.mysql',
'NAME': 'ringi',
'USER': 'root',
'PASSWORD': '',
'HOST': 'localhost',
'PORT': '3306',
},
}
Я добавил отображение в settings.py
DATABASE_APPS_MAPPING = {
'ringi':'ringi_db',
}
маршрутизатор базы данных определяется следующим образом
class dbrouter:
def db_for_read(self, model, **hints):
if model._meta.app_label == 'polls':
return 'ringi_db'
else:
return None
def db_for_write(self, model, **hints):
if model._meta.app_label == 'polls':
return 'ringi_db'
else:
return None
def allow_relation(self, obj1, obj2, **hints):
if obj1._meta.app_label == 'polls' or obj2._meta.app_label == 'polls':
return True
return None
def allow_migrate(self, db, app_label, model_name=None, **hints):
if app_label == 'polls':
return db == 'ringi_db'
return None
models.py
#### Book table should be stored in mypage db ####
class Book(models.Model):
title = models.CharField(max_length=100)
author = models.CharField(max_length=100)
publication_date = models.DateField()
isbn = models.CharField(max_length=13)
def __str__(self):
return self.title
class Meta:
db_table = 'book'
# Member table should be stored in ringi db #
class Member(models.Model):
name = models.CharField(max_length=100)
email = models.EmailField(unique=True)
address = models.CharField(max_length=255)
def __str__(self):
return self.name
class Meta:
db_table = 'member'
app_label = 'polls'
Когда я запускаю python manage.py makemigrations polls
, создается только миграция для книги.
Я прочитал другие ответы из здесь и я запутался в app_label, который, кажется, должен быть таким же, как имя приложения. Пожалуйста, подскажите, где я допускаю ошибку