Django项目同时连接多个不同的数据库(7)

简介: 【7月更文挑战第7天】在Django项目中配置连接多个数据库,你需要:1. 在`settings.py`中配置多个数据库,2. 在`settings.py`内设置数据库路由,指定每个应用使用的数据库,

项目需要连接多个不同的数据库,不同的应用操作不同的库。

以下是具体的修改步骤:

一、修改setting.py中的 DATABASES

DATABASES = {
    'default': {
    },
    'mysql': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'zz', # 数据库名称
        'HOST': '127.0.0.1', # 数据库地址,本机 ip 地址 127.0.0.1
        'PORT': 3306, # 端口
        'USER': 'root',  # 数据库用户名
        'PASSWORD': 'root', # 数据库密码
    },
    'postgress': {
        'ENGINE': 'django.db.backends.postgresql',
        'NAME': 'postgres',
        'USER': 'postgres',
        'PASSWORD': '',
        'HOST': '127.0.0.1',
        'PORT': '5432',
    },
}


2、还是在setting.py文件中配置应用对应的数据库


  • # 配置数据库操作路由
  • DATABASE_ROUTERS = ['application.database_router.DatabaseAppsRouter']
  • DATABASE_APPS_MAPPING = {
  • 'app1':'mysql',
  • 'app2':'postgress',
  • }

3、在setting.py同目录下新建 database_router.py文件

image.png


添加以下代码

  • # -*- coding: utf-8 -*-
  • 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
  • def allow_migrate(self, db, app_label, model=None, **hints):
  • """
  •        Make sure the auth app only appears in the 'auth_db'
  •        database.
  •        """
  • if db in DATABASE_MAPPING.values():
  • return DATABASE_MAPPING.get(app_label) == db
  • elif app_label in DATABASE_MAPPING:
  • return False
  • return None



ok!然后就可以创建模型,在对应的app中操作数据库了。































.

目录
相关文章
|
1月前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
126 68
|
29天前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
44 3
|
29天前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
28 1
|
29天前
|
Java 数据库连接 数据库
Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销
本文深入探讨了Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销,显著提升了系统的响应速度和吞吐量。文章介绍了连接池的工作原理,并以HikariCP为例,展示了如何在Java应用中使用连接池。通过合理配置和优化,连接池技术能够有效提升应用性能。
43 1
|
1月前
|
SQL 关系型数据库 数据库连接
"Nacos 2.1.0版本数据库配置写入难题破解攻略:一步步教你排查连接、权限和配置问题,重启服务轻松解决!"
【10月更文挑战第23天】在使用Nacos 2.1.0版本时,可能会遇到无法将配置信息写入数据库的问题。本文将引导你逐步解决这一问题,包括检查数据库连接、用户权限、Nacos配置文件,并提供示例代码和详细步骤。通过这些方法,你可以有效解决配置写入失败的问题。
56 0
|
28天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
139 45
|
29天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
43 2
|
1月前
|
安全 数据库 C++
Python Web框架比较:Django vs Flask vs Pyramid
Python Web框架比较:Django vs Flask vs Pyramid
40 1
|
3月前
|
机器学习/深度学习 人工智能 算法
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
植物病害识别系统。本系统使用Python作为主要编程语言,通过收集水稻常见的四种叶片病害图片('细菌性叶枯病', '稻瘟病', '褐斑病', '稻瘟条纹病毒病')作为后面模型训练用到的数据集。然后使用TensorFlow搭建卷积神经网络算法模型,并进行多轮迭代训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地模型文件。再使用Django搭建Web网页平台操作界面,实现用户上传一张测试图片识别其名称。
136 22
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
|
2月前
|
安全 数据库 C++
Python Web框架比较:Django vs Flask vs Pyramid
Python Web框架比较:Django vs Flask vs Pyramid
34 4