Django app配置多个数据库代码实例
这篇文章主要介绍了Djangoapp配置多个数据库代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
每个app使用不同的数据库
1.配置数据库连接
#settings.py
#DATABASES中必须要有default字段
DATABASES={
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'db',
'USER':'',
'PASSWORD':'',
'HOST':"localhost",
'OPTIONS':{'init_command':'SETdefault_storage_engine=INNODB;'}
},
'db1':{
'ENGINE':'django.db.backends.mysql',
'NAME':'db1',
'USER':'',
'PASSWORD':'',
'HOST':"localhost",
'OPTIONS':{'init_command':'SETdefault_storage_engine=INNODB;'}
}
}
2.配置数据库路由
#settings.py
DATABASES_APPS_MAPPING={
'app1':'default',
'app2':'db1',
}
DATABASE_ROUTERS=['utils.database_router.DatabaseAppsRouter']
3.数据库路由文件:
fromdjango.confimportsettings classDatabaseAppsRouter(object): defdb_for_read(self,model,**hints): app_label=model._meta.app_label ifapp_labelinsettings.DATABASES_APPS_MAPPING: returnsettings.DATABASES_APPS_MAPPING[app_label] returnNone defdb_for_write(self,model,**hints): app_label=model._meta.app_label ifapp_labelinsettings.DATABASES_APPS_MAPPING: returnsettings.DATABASES_APPS_MAPPING[app_label] returnNone
至此,使用app1的model会访问default数据库,使用app2的model会访问db1数据库
同一个app下使用不同数据库
只需要在modelclass中修改app_label的值即可,app_label默认为此model所在app的名称
classBook2(models.Model): author=models.CharField(max_length=1024,blank=True,null=True) title=models.CharField(max_length=1024) classMeta: app_label='db1'
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短