首页 > 数据库 >【Django】django 多数据库配置

【Django】django 多数据库配置

时间:2022-12-02 16:56:03浏览次数:44  
标签:DATABASE models MAPPING 数据库 db label Django django app

在django项目中, 一个工程中存在多个APP应用很常见. 有时候希望不同的APP连接不同的数据库,这个时候需要建立多个数据库连接。

1. 修改项目的 settings 配置

在 settings.py 中配置需要连接的多个数据库连接串

1 2 3 4 5 6 7 8 9 10 11 12 13 14 DATABASES = {   'default': {     'ENGINE': 'django.db.backends.sqlite3',     'NAME': os.path.join(BASE_DIR, 'sqlite3'),   },   'db01': {     'ENGINE': 'django.db.backends.sqlite3',     'NAME': os.path.join(BASE_DIR, 'db_01'),   },   'db02': {     'ENGINE': 'django.db.backends.sqlite3',     'NAME': os.path.join(BASE_DIR, 'db_02'),   }, }

假设现在我们用到3个数据库,一个default默认库,一个 db01 和 db02

2. 设置数据库的路由规则方法

在 settings.py 中配置 DATABASE_ROUTERS

1 DATABASE_ROUTERS = ['Prject.database_router.DatabaseAppsRouter']

Project: 建立的django项目名称(project_name)

database_router: 定义路由规则database_router.py 文件名称, 这个文件名可以自己定义

DatabaseAppsRouter: 路由规则的类名称,这个类是在database_router.py 文件中定义

3. 设置APP对应的数据库路由表

每个APP要连接哪个数据库,需要在做匹配设置,在 settings.py 文件中做如下配置:

1 2 3 4 5 6 7 8 9 10 DATABASE_APPS_MAPPING = {   # example:   # 'app_name':'database_name',   'app02': 'db02',   'app01': 'db01',   'admin': 'db01',   'auth': 'db01',   'contenttypes': 'db01',   'sessions': 'db01', }

以上的app01, app02是项目中的 APP名,分别指定到 db01, db02 的数据库。

为了使django自己的表也创建到你自己定义的数据库中,你可以指定 : admin, auth, contenttypes, sessions 到设定的数据库中,如果不指定则会自动创建到默认(default)的数据库中

4. 创建数据库路由规则

在项目工程根路径下(与 settings.py 文件一级)创建 database_router.py 文件:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 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

5. Models创建样例

在各自的 APP 中创建数据表的models时,必须要指定表的 app_label 名字,如果不指定则会创建到 default 中配置的数据库名下,

如下:

在app01下创建models

1 2 3 4 5 6 7 class Users(models.Model):   name = models.CharField(max_length=50)   passwd = models.CharField(max_length=100)   def __str__(self):     return "app01 %s " % self.name   class Meta:     app_label = "app01"

在app02下创建models

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 class Users(models.Model):   username = models.CharField(max_length=100)   password = models.CharField(max_length=50)   age = models.IntegerField()   def __str__(self):     return "app02 %s" % self.username   class Meta:     app_label = "app02" class Book(models.Model):   user = models.ForeignKey("Users", on_delete=models.CASCADE)   bookname = models.CharField(max_length=100)   def __str__(self):     return "%s: %s" % (self.user.username, self.bookname)   class Meta:     app_label = "app02"

在 app03创建models 未指定 app_label,创建到default下

1 2 class Users(models.Model):    username = models.CharField(max_length=100)

6. 生成数据表

在使用django的 migrate 创建生成表的时候,需要加上 –database 参数,如果不加则将 未 指定 app_label 的 APP的models中的表创建到default指定的数据库中,如:

将app01下models中的表创建到db01的数据库”db_01”中

1 ./ manage.py migrate --database=db01

将app02下models中的表创建到db02的数据库”db_02”中

1 ./ manage.py migrate --database=db02

将app03下models中的表创建到default的数据库”sqlite3”中

1 ./ manage.py migrate

以上创建完成后,其它所有的创建、查询、删除等操作就和普通一样操作就可以了,无需再使用类似

1 models.User.objects.using(dbname).all()

这样的方式来操作。

标签:DATABASE,models,MAPPING,数据库,db,label,Django,django,app
From: https://www.cnblogs.com/gtea/p/16944943.html

相关文章

  • (转载)SQL Server 2005 数据库快照(database Snapshot)
    数据库快照(atabasesnapshot)是一个只读的,静态的数据库视图。一个数据库可以有多个数据库快照,每个数据库快照在被显性的删除之前将一直存在。数据库快照将保持和源数据库快......
  • 数据库面试题--Mysql
    MySQL1.什么是索引?2.索引是个什么样的数据结构呢?3.Hash索引和B+树索引有什么区别或者说优劣呢?4.在建立索引的时候,都有哪些需要考虑的因素呢?5.了解过哪些存储引......
  • 数据库面试题--Mybatis
    Mybatis1.什么是Mybatis?2.Mybatis的优缺点?3.Mybatis使用场合?4.#{}和${}的区别是什么?5.当实体类的属性名和表种字段名不一致怎么办?6.Mybatis是如何将sql执行结果......
  • 数据库面试题--Mycat
    Mycat1.Mycat是什么?2.什么叫混合切分3.在项目组中,切分后的库从哪里而来?4.搭建mycat的核心配置文件有哪些?5.mycat分库可以分成100个库吗?6.进行库表拆分时,拆分规则怎......
  • 数据库面试题--Redis
    Redis1.什么是Redis?简述它的优缺点?2.Redis相比memcached有哪些优势?3.Redis有哪些数据结构?4.Redis主要消耗什么物理资源?5.Redis的全称是什么?6.一个字符串类型的值能......
  • 数据库三大范式-2022-12-2
    为什么要规范化?  1、信息重复  2、更新异常 3、插入异常   ---无法正常显示信息 4、删除异常   ---丢失有效信息三大范式概念解释:三大范式......
  • 设计一个项目的数据库
    糟糕的数据库设计   --数据冗余,浪费空间   --数据库插入和删除比较麻烦   --程序性能差  良好的数据设计设计数据库的步骤(个人博客) 1、收集......
  • 【Golang】数据库使用
    非结构化方式获取数据库结果动态列获取结果https://github.com/go-sql-driver/mysql/wiki/Examples#rawbytes......
  • vs.net 2010两个数据库方面的好工具
    今天发现vs.net2010在处理数据库方面的两个不错的工具,分别是数据异同比较器和数据架构比较器,使用起来都很简单,要学习的话,可以从下面两个连接......
  • mongodb中重命名一个数据库
    MongoDB并没有提供renameDatabase的命令,用户的想法是通过copydb来实现,先将数据库拷贝一份,然后删除老的数据库,但由于DB里数据很多,copydb太耗时,想知道是......