Skip to content

Commit

Permalink
添加多数据库路由支持
Browse files Browse the repository at this point in the history
  • Loading branch information
wuyue92tree committed Apr 22, 2018
1 parent a6adfeb commit 6a88318
Show file tree
Hide file tree
Showing 3 changed files with 66 additions and 0 deletions.
8 changes: 8 additions & 0 deletions rest_backend/settings/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,14 @@
}
}

# 添加路由
DATABASE_ROUTERS = ['rest_backend.utils.database_router.DatabaseAppsRouter']
DATABASE_APPS_MAPPING = {
# example:
# 'app_name':'database_name',
'accounts': 'default',
}

# Password validation
# https://docs.djangoproject.com/en/2.0/ref/settings/#auth-password-validators

Expand Down
Empty file added rest_backend/utils/__init__.py
Empty file.
58 changes: 58 additions & 0 deletions rest_backend/utils/database_router.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#! /usr/bin/env python
# -*- coding: utf-8 -*-
"""
@author: wuyue
@contact: [email protected]
@software: PyCharm
@file: database_router.py
@create at: 2018-04-22 12:53
这一行开始写关于本文件的说明与解释
"""

from django.conf import settings

DATABASE_MAPPING = settings.DATABASE_APPS_MAPPING


class DatabaseAppsRouter(object):
"""
A router to control all database operations on models for different
databases.
In case an app is not set in settings.DATABASE_APPS_MAPPING, the router
will fallback to the `default` database.
Settings example:
DATABASE_APPS_MAPPING = {'app1': 'db1', 'app2': 'db2'}
"""

def db_for_read(self, model, **hints):
""""Point all read operations to the specific database."""
if model._meta.app_label in DATABASE_MAPPING:
return DATABASE_MAPPING[model._meta.app_label]
return None

def db_for_write(self, model, **hints):
"""Point all write operations to the specific database."""
if model._meta.app_label in DATABASE_MAPPING:
return DATABASE_MAPPING[model._meta.app_label]
return None

def allow_relation(self, obj1, obj2, **hints):
"""Allow any relation between apps that use the same database."""
db_obj1 = DATABASE_MAPPING.get(obj1._meta.app_label)
db_obj2 = DATABASE_MAPPING.get(obj2._meta.app_label)
if db_obj1 and db_obj2:
if db_obj1 == db_obj2:
return True
else:
return False
return None

def allow_syncdb(self, db, model):
"""Make sure that apps only appear in the related database."""

if db in DATABASE_MAPPING.values():
return DATABASE_MAPPING.get(model._meta.app_label) == db
elif model._meta.app_label in DATABASE_MAPPING:
return False
return None

0 comments on commit 6a88318

Please sign in to comment.