Django app配置多个数据库代码实例
2020-03-22 12:07
936 查看
这篇文章主要介绍了Django app配置多个数据库代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
每个app使用不同的数据库
1. 配置数据库连接
# settings.py # DATABASES中必须要有default字段 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'db', 'USER': '', 'PASSWORD': '', 'HOST': "localhost", 'OPTIONS': {'init_command': 'SET default_storage_engine=INNODB;'} }, 'db1': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'db1', 'USER': '', 'PASSWORD': '', 'HOST': "localhost", 'OPTIONS': {'init_command': 'SET default_storage_engine=INNODB;'} } }
2. 配置数据库路由
# settings.py DATABASES_APPS_MAPPING = { 'app1': 'default', 'app2': 'db1', } DATABASE_ROUTERS = ['utils.database_router.DatabaseAppsRouter']
3. 数据库路由文件:
from django.conf import settings class DatabaseAppsRouter(object): def db_for_read(self, model, **hints): app_label = model._meta.app_label if app_label in settings.DATABASES_APPS_MAPPING: return settings.DATABASES_APPS_MAPPING[app_label] return None def db_for_write(self, model, **hints): app_label = model._meta.app_label if app_label in settings.DATABASES_APPS_MAPPING: return settings.DATABASES_APPS_MAPPING[app_label] return None
至此,使用app1的model会访问default数据库,使用app2的model会访问db1数据库
同一个app下使用不同数据库
只需要在model class中修改app_label的值即可,app_label默认为此model所在app的名称
class Book2(models.Model): author = models.CharField(max_length=1024, blank=True, null=True) title = models.CharField(max_length=1024) class Meta: app_label = 'db1'
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- Django+mysql配置与简单操作数据库实例代码
- Django+mysql配置与简单操作数据库实例
- django3.02模板中的超链接配置实例代码
- C#中读取App.config配置文件代码实例
- django 按时间范围查询数据库实例代码
- c# 如何在App.cofig文件里面配置数据库连接并且获取连接的简单实例
- 数据库配置,参考django框架,采用嵌套的字典实现
- Opencv2.4.9、VS2010配置及grabcut代码实例
- pycharm下Django项目,配置路由时报错:include() got an unexpected keyword argument 'app_name'
- spring-通过JdbcTemplate进行数据库操作-代码实现,无配置文件
- Django记-环境配置与实例运行
- 实例代码-判断是否安装app的代码
- 如何从代码中获取hibernate中配置的数据库方言信息
- Spring动态对Quartz定时任务的管理,实现动态加载,停止的配置实例代码
- C# 通过窗体修改配置文件的代码 App.config
- MyBatis获取数据库自生成的主键Id详解及实例代码
- TomCat6.0数据库连接池配置实例(Oracle 10g数据库)
- 在编写SSH框架的数据库连接代码运行时报错,配置好数据库方言后,它说让我重新配置,求大神帮忙,蟹蟹
- JS操作数据库的实例代码
- Win Oracle 监听文件配置参考代码实例