一个Django应用/模型到多个数据库



我在一个Django项目上& &;出于性能和路线图的考虑,我将需要使用Multi-BDD系统。

然而,我有点卡住了,让我解释一下自己,我创建了数据库,我添加了一个路由URL来指定使用哪个数据库以及何时使用它。我有一个单一的"应用程序在这个项目",也有一个单一的&唯一的"数据库模型",最后一个(模型)逻辑上必须在迁移期间复制到我的所有数据库中。问题:

为什么当我迁移这个模型时,它只在一个数据库中迁移,而不是在另一个数据库中迁移,而迁移表是重复的,我无法理解为什么和如何🙂我将感谢您的反馈。提前谢谢你!

这是我的settings.py

# Including le DB_Router
DATABASE_ROUTERS = ['routers.db_routers.AuthRouter',
'routers.db_routers.VIGRouter',
'routers.db_routers.VISRouter',
'routers.db_routers.DURRouter',
'routers.db_routers.IPCRouter',
]
DATABASES = {
'default': {},
'izlog': {
'ENGINE': ENGINE,
'NAME': 'izlog',
'USER': USER,
'PASSWORD': PASSWORD,
'HOST': HOST,
'PORT': PORT,
},
'db_vig': {
'ENGINE': ENGINE,
'NAME': DBSNAME['db_VIG'],
'USER': USER,
'PASSWORD': PASSWORD,
'HOST': HOST,
'PORT': PORT,
},
'db_vis': {
'ENGINE': ENGINE,
'NAME': DBSNAME['db_VIS'],
'USER': USER,
'PASSWORD': PASSWORD,
'HOST': HOST,
'PORT': PORT,
},
这是我的db_routers.py

class VIGRouter:
route_app_labels = {'izLogApp'}
def db_for_read(self, model, **hints):
if model._meta.app_label in self.route_app_labels:
return 'db_vig'
return None
def db_for_write(self, model, **hints):
if model._meta.app_label in self.route_app_labels:
return 'db_vig'
return None
def allow_migrate(self, db, app_label, model_name=None, **hints):
if app_label in self.route_app_labels:
return db == 'db_vig'
return None

class VISRouter:
route_app_labels = {'izLogApp'}
def db_for_read(self, model, **hints):
if model._meta.app_label in self.route_app_labels:
return 'db_vis'
return None
def db_for_write(self, model, **hints):
if model._meta.app_label in self.route_app_labels:
return 'db_vis'
return None
def allow_migrate(self, db, app_label, model_name=None, **hints):
if app_label in self.route_app_labels:
return db == 'db_vis'
return None

这是我的模型

class log_weblinks(models.Model):
id_societe = models.CharField(max_length=32, null=True)
code_client = models.CharField(max_length=32, null=True)
date = models.DateTimeField(null=True)
log = models.CharField(max_length=32, null=True)
def __str__(self):
return self.id_societe
def readableDateCommande(self):
date_time_obj = datetime.datetime.strptime(self.date, '%Y%m%d')
return date_time_obj.strftime('%Y-%m-%d HH:MM:SS')

class connexion_log_weblinks(models.Model):
id_societe = models.CharField(max_length=32, null=True)
code_client = models.CharField(max_length=32, null=True)
date = models.DateTimeField(null=True)
log = models.CharField(max_length=32, null=True)
def __str__(self):
return self.log
def readableDateCommande(self):
date_time_obj = datetime.datetime.strptime(self.date, '%Y%m%d')
return date_time_obj.strftime('%Y-%m-%d HH:MM:SS')

我猜您使用pythonmanage.py migrate来应用您的迁移。此命令仅适用于默认数据库。当运行多数据库应用程序时,您需要使用--database选项指定目标数据库。

例如:python manage.py migrate --database db_vig

最新更新