电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Django多數(shù)據(jù)庫(kù)聯(lián)用實(shí)現(xiàn)方法解析

瀏覽:140日期:2024-09-19 11:51:21

本文講述在一個(gè) django project 中使用多個(gè)數(shù)據(jù)庫(kù)的方法, 多個(gè)數(shù)據(jù)庫(kù)的聯(lián)用 以及多數(shù)據(jù)庫(kù)時(shí)數(shù)據(jù)導(dǎo)入導(dǎo)出的方法。

直接給出一種簡(jiǎn)單的方法吧,想了解更多的到官方教程,點(diǎn)擊此處

代碼

1. 每個(gè)app都可以單獨(dú)設(shè)置一個(gè)數(shù)據(jù)庫(kù)

settings.py中有數(shù)據(jù)庫(kù)的相關(guān)設(shè)置,有一個(gè)默認(rèn)的數(shù)據(jù)庫(kù) default,我們可以再加一些其它的,比如:

# Database# https://docs.djangoproject.com/en/1.8/ref/settings/#databasesDATABASES = { ’default’: { ’ENGINE’: ’django.db.backends.sqlite3’, ’NAME’: os.path.join(BASE_DIR, ’db.sqlite3’), }, ’db1’: { ’ENGINE’: ’django.db.backends.mysql’, ’NAME’: ’dbname1’, ’USER’: ’your_db_user_name’, ’PASSWORD’: ’yourpassword’, 'HOST': 'localhost', }, ’db2’: { ’ENGINE’: ’django.db.backends.mysql’, ’NAME’: ’dbname2’, ’USER’: ’your_db_user_name’, ’PASSWORD’: ’yourpassword’, 'HOST': 'localhost', },} # use multi-database in django# add by WeizhongTuDATABASE_ROUTERS = [’project_name.database_router.DatabaseAppsRouter’]DATABASE_APPS_MAPPING = { # example: #’app_name’:’database_name’, ’app1’: ’db1’, ’app2’: ’db2’,}

在project_name文件夾中存放 database_router.py 文件,內(nèi)容如下:

# -*- 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 # for Django 1.4 - Django 1.6 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 # Django 1.7 - Django 1.11 def allow_migrate(self, db, app_label, model_name=None, **hints): print db, app_label, model_name, hints if db in DATABASE_MAPPING.values(): return DATABASE_MAPPING.get(app_label) == db elif app_label in DATABASE_MAPPING: return False return None

這樣就實(shí)現(xiàn)了指定的 app 使用指定的數(shù)據(jù)庫(kù)了,當(dāng)然你也可以多個(gè)sqlite3一起使用,相當(dāng)于可以給每個(gè)app都可以單獨(dú)設(shè)置一個(gè)數(shù)據(jù)庫(kù)!如果不設(shè)置或者沒(méi)有設(shè)置的app就會(huì)自動(dòng)使用默認(rèn)的數(shù)據(jù)庫(kù)。

2.使用指定的數(shù)據(jù)庫(kù)來(lái)執(zhí)行操作

在查詢的語(yǔ)句后面用 using(dbname) 來(lái)指定要操作的數(shù)據(jù)庫(kù)即可

# 查詢YourModel.objects.using(’db1’).all() 或者 YourModel.objects.using(’db2’).all()# 保存 或 刪除user_obj.save(using=’new_users’)user_obj.delete(using=’legacy_users’)

3.多個(gè)數(shù)據(jù)庫(kù)聯(lián)用時(shí)數(shù)據(jù)導(dǎo)入導(dǎo)出

使用的時(shí)候和一個(gè)數(shù)據(jù)庫(kù)的區(qū)別是:

如果不是defalut(默認(rèn)數(shù)據(jù)庫(kù))要在命令后邊加 --database=數(shù)據(jù)庫(kù)對(duì)應(yīng)的settings.py中的名稱 如: --database=db1 或 --database=db2

數(shù)據(jù)庫(kù)同步(創(chuàng)建表)

# Django 1.6及以下版本python manage.py syncdb #同步默認(rèn)的數(shù)據(jù)庫(kù),和原來(lái)的沒(méi)有區(qū)別# 同步數(shù)據(jù)庫(kù) db1 (注意:不是數(shù)據(jù)庫(kù)名是db1,是settings.py中的那個(gè)db1,不過(guò)你可以使這兩個(gè)名稱相同,容易使用)python manage.py syncdb --database=db1# Django 1.7 及以上版本python manage.py migrate --database=db1

數(shù)據(jù)導(dǎo)出

python manage.py dumpdata app1 --database=db1 > app1_fixture.jsonpython manage.py dumpdata app2 --database=db2 > app2_fixture.jsonpython manage.py dumpdata auth > auth_fixture.json

數(shù)據(jù)庫(kù)導(dǎo)入

python manage.py loaddata app1_fixture.json --database=db1python manage.py loaddata app2_fixture.json --database=db2

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 深圳网站建设-高端企业网站开发-定制网页设计制作公司 | 西安文都考研官网_西安考研辅导班_考研培训机构_西安在职考研培训 | 【孔氏陶粒】建筑回填陶粒-南京/合肥/武汉/郑州/重庆/成都/杭州陶粒厂家 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 偏心半球阀-电动偏心半球阀-调流调压阀-旋球阀-上欧阀门有限公司 | 北京律师咨询_知名专业北京律师事务所_免费法律咨询 | 氧化铁红厂家-淄博宗昂化工 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 苏州同创电子有限公司 - 四探针测试仪源头厂家 | 苏州西朗门业-欧盟CE|莱茵UL双认证的快速卷帘门品牌厂家 | 车牌识别道闸_停车场收费系统_人脸识别考勤机_速通门闸机_充电桩厂家_中全清茂官网 | 包装设计公司,产品包装设计|包装制作,包装盒定制厂家-汇包装【官方网站】 | 北京浩云律师事务所-企业法律顾问_破产清算等公司法律服务 | 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | 展厅设计公司,展厅公司,展厅设计,展厅施工,展厅装修,企业展厅,展馆设计公司-深圳广州展厅设计公司 | 昆山新莱洁净应用材料股份有限公司-卫生级蝶阀,无菌取样阀,不锈钢隔膜阀,换向阀,离心泵 | J.S.Bach 圣巴赫_高端背景音乐系统_官网| 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 517瓜水果特产网|一个专注特产好物的网站 | 杭州顺源过滤机械有限公司官网-压滤机_板框压滤机_厢式隔膜压滤机厂家 | 深圳市宏康仪器科技有限公司-模拟高空低压试验箱-高温防爆试验箱-温控短路试验箱【官网】 | 新疆系统集成_新疆系统集成公司_系统集成项目-新疆利成科技 | 长城人品牌官网| 菲希尔FISCHER测厚仪-铁素体检测仪-上海吉馨实业发展有限公司 | 工装定制/做厂家/公司_工装订做/制价格/费用-北京圣达信工装 | 电磁流量计厂家_涡街流量计厂家_热式气体流量计-青天伟业仪器仪表有限公司 | 电抗器-能曼电气-电抗器专业制造商 | 南京欧陆电气股份有限公司-风力发电机官网 | 水稻烘干机,小麦烘干机,大豆烘干机,玉米烘干机,粮食烘干机_巩义市锦华粮食烘干机械制造有限公司 水环真空泵厂家,2bv真空泵,2be真空泵-淄博真空设备厂 | cnc精密加工_数控机械加工_非标平键定制生产厂家_扬州沃佳机械有限公司 | 结晶点测定仪-润滑脂滴点测定仪-大连煜烁 | 【甲方装饰】合肥工装公司-合肥装修设计公司,专业从事安徽办公室、店面、售楼部、餐饮店、厂房装修设计服务 | 贵州自考_贵州自学考试网| 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 成都离婚律师|成都结婚律师|成都离婚财产分割律师|成都律师-成都离婚律师网 | 自动钻孔机-全自动数控钻孔机生产厂家-多米(广东)智能装备有限公司 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 包装机_厂家_价格-山东包装机有限公司 | 铝合金风口-玻璃钢轴流风机-玻璃钢屋顶风机-德州东润空调设备有限公司 | 广东青藤环境科技有限公司-水质检测 |