Django中多个数据库的路由和中间件

时间:2019-05-08 18:29:05

标签: python django django-database

我在正确设置中间件和路由器以支持多个数据库时遇到问题,每种语言一个(我决定将它们分开)。

我尝试使用this solution,但是到目前为止,我并没有太多使用它。

在我的 settings.py 中,数据库和中间件的定义如下:

DATABASES = {
    'default': {},
    'ru': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'db_ru.sqlite3',
    },
    'en': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'db_en.sqlite3',
    }
}

DATABASE_ROUTERS = ['me.middleware.database_routing.DatabaseRouter']

MIDDLEWARE = [
    'me.middleware.database_routing.RouterMiddleware',
    'django.middleware.security.SecurityMiddleware',
    'whitenoise.middleware.WhiteNoiseMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.locale.LocaleMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
'me.middleware.database_routing'中使用的

database_routing.py 完全对应于this middleware

启动服务器时出现错误: RouterMiddleware()不接受任何参数。我相信中间件代码存在一些缺陷。另外,我无法迁移到数据库,我得到了ValueError: Cannot assign "<ContentType: ContentType object (1)>": the current database router prevents this relation.

也许还有其他解决方法?

1 个答案:

答案 0 :(得分:0)

如果您的database_routing.py包含以下部分,则它将停止在Django中创建的关系。

因此,请尝试在注释行中添加注释,仅返回true。 这对我有用!

def allow_relation(self, obj1, obj2, **hints):
        """
        Do not allow relations involving the remote database
        """
        # print("in allow relation")
        # if obj1._meta.app_label == Organization or \
        #    obj2._meta.app_label == Organization:
        #    return True
        # return None
        return True