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

1. 修改项目的 settings 配置 
在 settings.py 中配置需要连接的多个数据库连接串

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

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

2. 设置数据库的路由规则方法 
在 settings.py 中配置 DATABASE_ROUTERS

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

Project: 建立的django项目名称(project_name) 
database_router: 定义路由规则database_router.py 文件名称, 这个文件名可以自己定义 
DatabaseAppsRouter: 路由规则的类名称,这个类是在database_router.py 文件中定义

3. 设置APP对应的数据库路由表 
每个APP要连接哪个数据库,需要在做匹配设置,在 settings.py 文件中做如下配置:

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

以上的app01, app02是项目中的 APP名,分别指定到 db01, db02 的数据库。 
为了使django自己的表也创建到你自己定义的数据库中,你可以指定 : admin, auth, contenttypes, sessions 到设定的数据库中,如果不指定则会自动创建到默认(default)的数据库中

4. 创建数据库路由规则 
在项目工程根路径下(与 settings.py 文件一级)创建 database_router.py 文件:

  1. from django.conf import settings
  2. DATABASE_MAPPING = settings.DATABASE_APPS_MAPPING
  3. class DatabaseAppsRouter(object):
  4. """
  5. A router to control all database operations on models for different
  6. databases.
  7. In case an app is not set in settings.DATABASE_APPS_MAPPING, the router
  8. will fallback to the `default` database.
  9. Settings example:
  10. DATABASE_APPS_MAPPING = {'app1': 'db1', 'app2': 'db2'}
  11. """
  12. def db_for_read(self, model, **hints):
  13. """"Point all read operations to the specific database."""
  14. if model._meta.app_label in DATABASE_MAPPING:
  15. return DATABASE_MAPPING[model._meta.app_label]
  16. return None
  17. def db_for_write(self, model, **hints):
  18. """Point all write operations to the specific database."""
  19. if model._meta.app_label in DATABASE_MAPPING:
  20. return DATABASE_MAPPING[model._meta.app_label]
  21. return None
  22. def allow_relation(self, obj1, obj2, **hints):
  23. """Allow any relation between apps that use the same database."""
  24. db_obj1 = DATABASE_MAPPING.get(obj1._meta.app_label)
  25. db_obj2 = DATABASE_MAPPING.get(obj2._meta.app_label)
  26. if db_obj1 and db_obj2:
  27. if db_obj1 == db_obj2:
  28. return True
  29. else:
  30. return False
  31. return None
  32. def allow_syncdb(self, db, model):
  33. """Make sure that apps only appear in the related database."""
  34. if db in DATABASE_MAPPING.values():
  35. return DATABASE_MAPPING.get(model._meta.app_label) == db
  36. elif model._meta.app_label in DATABASE_MAPPING:
  37. return False
  38. return None
  39. def allow_migrate(self, db, app_label, model=None, **hints):
  40. """
  41. Make sure the auth app only appears in the 'auth_db'
  42. database.
  43. """
  44. if db in DATABASE_MAPPING.values():
  45. return DATABASE_MAPPING.get(app_label) == db
  46. elif app_label in DATABASE_MAPPING:
  47. return False
  48. return None
  • 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
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61

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

app01下创建models

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

app02下创建models

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

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

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

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

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

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

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

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

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

  1. ./ manage.py migrate
  • 1

以上创建完成后,其它所有的创建、查询、删除等操作就和普通一样操作就可以了,无需再使用类似 
models.User.objects.using(dbname).all() 
这样的方式来操作

django 多数据库配置的更多相关文章

  1. Django models数据库配置以及多数据库联用设置

    今天来说说web框架Django怎么配置使用数据库,也就是传说中MVC(Model View Controller)中的M,Model(模型). 简单介绍一下Django中的MVC: 模型(model ...

  2. django mysql 数据库配置

    在settings.py中保存了数据库的连接配置信息,Django默认初始配置使用sqlite数据库. DATABASES = { 'default': { 'ENGINE': 'django.db. ...

  3. django的数据库配置-13

    数据库配置 打开mysite下的settings.py文件 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NA ...

  4. Django models数据库配置以及多数据库调用设置

    今天来说说web框架Django怎么配置使用数据库,也就是传说中MVC(Model View Controller)中的M,Model(模型). 简单介绍一下Django中的MVC: 模型(model ...

  5. django学习-数据库配置-创建模型

    数据库配置 在mysite/settings.py中,包含了django项目设置的python模块 通常,这个配置文件使用SQLite作为默认数据库.如果你不熟悉数据库,或者只是想尝试下django, ...

  6. Django使用数据库(配置数据库,基本的增删改查a)

    第一步在setting文件中配置DATABASES设置 然后更改__init__文件 打开APP中models文件,导入并创建数据库 最后打开终端执行以下命令 python manage.py mak ...

  7. django数据库配置,即数据库分库分表

    一 Django的数据库配置 (一)修改settings.py文件关于数据库的配置: Django默认使用sqlite:   DATABASES = { 'default': { 'ENGINE': ...

  8. Django ORM 数据库设置和读写分离

    一 Django的数据库配置 (一)修改settings.py文件关于数据库的配置: Django默认使用sqlite: DATABASES = { 'default': { 'ENGINE': 'd ...

  9. Django数据库配置

    将Django使用数据库由默认的sqlite3更改为mysql: 1.安装mysql驱动程序 MySQLdb(mysql-python) mysqlclient Connector/Python Py ...

随机推荐

  1. 存储过程清理N天前数据

    CREATE OR REPLACE PROCEDURE APICALL_LOG_INTERFACE_CLEAN ( CLEANDAY IN Number --天数 ) AS v_cleanDay nu ...

  2. Chrome自带恐龙小游戏的源码研究(四)

    在上一篇<Chrome自带恐龙小游戏的源码研究(三)>中实现了让游戏昼夜交替,这一篇主要研究如何绘制障碍物. 障碍物有两种:仙人掌和翼龙.仙人掌有大小两种类型,可以同时并列多个:翼龙按高. ...

  3. iOS开发人员程序许可协议

    请细致阅读以下的许可协议条款和条件之前下载或使用苹果软件.   这些条款和条件构成你和苹果之间的法律协议.   iOS开发人员程序许可协议   目的 你想使用苹果软件(例如以下定义)来开发一个或多个应 ...

  4. JQuery如何获取按键的unicode编码?

    $("selector").keyup(function(xxx){ var myEvent = xxx; var code = myEvent.keyCode; alert(co ...

  5. WPF SDK研究 之 数据绑定

    这一章介绍数据绑定.本章共计27个示例,全都在VS2008下.NET3.5测试通过,点击这里下载:ConnectedData.rar 1.ShowDataWithoutBinding注: <?M ...

  6. 如何进行Web服务的性能测试?

    随着浏览器功能的不断完善,用户量不断的攀升,涉及到web服务的功能在不断的增加,对于我们测试来说,我们不仅要保证服务端功能的正确性,也要验证服务端程序的性能是否符合要求.那么性能测试都要做些什么呢?我 ...

  7. 九度OJ 1053:互换最大最小数 (基础题)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:6613 解决:2676 题目描述: 输入一个数n,然后输入n个数值各不相同,调换数组中最大和最小的两个数,然后输出. 输入: 测试数据有多组 ...

  8. ABAP div / mod的用法

    1.divdiv是用于取两数相除的商的,c = a div b,得到的c的值就是a除b的商.2.// 是用于取两数相除的结果的.c = a / b,如果c是i数据类型的,这个语法会进行四舍五入的.3. ...

  9. SQL 中GROUP BY 、ROLLUP、CUBE 关系和区别

    转自:http://www.cnblogs.com/dyufei/archive/2009/11/12/2573974.html 不言自明,看SQL就完全理解了,不需要过多解释,不错,分享之: ROL ...

  10. IOS AFNetWorking 设置超时时间

    (原创经验总结) 1.关于AF 超时的说法 系统默认的timeInterval  是60s  ASI默认是10s 但是有一个说法是 AF “AFN在GET条件下设置的NSURLRequest能起作用, ...