日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Django多數據庫配置及逆向生成model教程

瀏覽:28日期:2024-10-18 10:46:10

在項目中我們每個app對應不同的數據庫,其中有一個是從數據庫逆向生成model,做個筆記。

1、修改項目的setting.py配置 :

DATABASES = { ’default’: { ’ENGINE’: ’django.db.backends.mysql’, # 默認用mysql ’NAME’: ’bk’, # 數據庫名 (默認與APP_ID相同) ’USER’: ’root’, # 你的數據庫user ’PASSWORD’: ’root’, # 你的數據庫password ’HOST’: ’xxx.xxx.xxx.xxx’, # 開發的時候,使用localhost ’PORT’: ’3306’, # 默認3306 }, ’cloudsino_test’: { ’ENGINE’: ’django.db.backends.mysql’, # 默認用mysql ’NAME’: ’cloudsino_test’, # 數據庫名 (默認與APP_ID相同) ’USER’: ’root’, # 你的數據庫user ’PASSWORD’: ’root’, # 你的數據庫password ’HOST’: ’xxx.xxx.xxx.xxx’, # 開發的時候,使用localhost ’PORT’: ’3306’, # 默認3306 },}# 設置數據庫的路由規則方法DATABASE_ROUTERS = [’conf.database_router.DatabaseAppsRouter’]# 設置APP對應的數據庫路由表,哪個app要連接哪個數據庫,沒有指定會用default那個。DATABASE_APPS_MAPPING = { # example: #’app_name’:’database_name’, ’home_application’: ’cloudsino_test’, ’cmdb’: ’default’,}

2、新建database_router.py:

在與setting.py文件同級的目錄下新建database_router.py文件:

# -*- coding: utf-8 -*-from settings_development import DATABASE_APPS_MAPPINGDATABASE_MAPPING = DATABASE_APPS_MAPPINGclass DatabaseAppsRouter(object): def db_for_read(self, model, **hints): ''''建議model類型對象從哪一個數據庫讀取.''' if model._meta.app_label in DATABASE_MAPPING: return DATABASE_MAPPING[model._meta.app_label] return None def db_for_write(self, model, **hints): '''建議model類型對象的寫入操作應該使用哪個數據庫''' 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. 如果obj1 和obj2 之間應該允許關聯則返回True,如果應該防止關聯則返回False,如果路由無法判斷則返回None ''' 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. 定義遷移操作是否允許在別名為db的數據庫上運行。如果操作應該運行則返回True ,如果不應該運行則返回False,如果路由無法判斷則返回None。 ''' if db in DATABASE_MAPPING.values(): return DATABASE_MAPPING.get(app_label) == db elif app_label in DATABASE_MAPPING: return False return None

3.逆向生成model:

在terminal中輸入以下命令,使用名為cloudsino_test的DATABASE來逆向生成model到home_application這個app的models.py:

python manage.py inspectdb --database=cloudsino_test > home_application/models.py

Django多數據庫配置及逆向生成model教程

逆向生成的model:

# This is an auto-generated Django model module.# You’ll have to do the following manually to clean this up:# * Rearrange models’ order# * Make sure each model has one field with primary_key=True# * Remove `managed = False` lines if you wish to allow Django to create, modify, and delete the table# Feel free to rename the models, but don’t rename db_table values or field names.## Also note: You’ll have to insert the output of ’django-admin sqlcustom [app_label]’# into your database.from __future__ import unicode_literalsfrom django.db import modelsclass CloudsinoCpuinfo(models.Model): corenumber = models.CharField(max_length=128) frequency = models.CharField(max_length=128) index = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) name = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) type = models.CharField(max_length=128) device = models.ForeignKey(’CloudsinoDevice’, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_cpuinfo’class CloudsinoDevice(models.Model): sn = models.CharField(max_length=128) app = models.CharField(max_length=128) business_chargeby1 = models.CharField(max_length=128) business_chargeby2 = models.CharField(max_length=128) chargeby1 = models.CharField(max_length=128) chargeby2 = models.CharField(max_length=128) description = models.CharField(max_length=128) device_status = models.CharField(max_length=128) devicename = models.CharField(max_length=128) field1 = models.CharField(max_length=128) field2 = models.CharField(max_length=128) field3 = models.CharField(max_length=128) field4 = models.CharField(max_length=128) field5 = models.CharField(max_length=128) frame_posiniton = models.CharField(max_length=128) framename = models.CharField(max_length=128) ip = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) model = models.CharField(max_length=128) os = models.CharField(max_length=128) position_desc = models.CharField(max_length=128) roomarea = models.CharField(max_length=128) roomname = models.CharField(max_length=128) servicetag = models.CharField(max_length=128) shape = models.CharField(max_length=128) specification = models.CharField(max_length=128) subtype = models.CharField(max_length=128) type = models.CharField(max_length=128) ucount = models.CharField(max_length=128) class Meta: managed = False db_table = ’cloudsino_device’class CloudsinoDevicetype(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) status = models.CharField(max_length=128) class Meta: managed = False db_table = ’cloudsino_devicetype’class CloudsinoDiskinfo(models.Model): bus = models.CharField(max_length=128) formfactor = models.CharField(max_length=128) index = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) media = models.CharField(max_length=128) name = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) size = models.CharField(max_length=128) speed = models.CharField(max_length=128) type = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_diskinfo’class CloudsinoFaninfo(models.Model): index = models.CharField(max_length=128) name = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_faninfo’class CloudsinoHbacardinfo(models.Model): name = models.CharField(max_length=128) wwnn = models.CharField(max_length=128) wwpn = models.CharField(max_length=128) fc_switch = models.CharField(max_length=128) switch_port = models.CharField(max_length=128) switch_mac = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_hbacardinfo’class CloudsinoManageinfo(models.Model): assetcode = models.CharField(max_length=128) department = models.CharField(max_length=128) express_code = models.CharField(max_length=128) service_level = models.CharField(max_length=128) shutdown_level = models.CharField(max_length=128) usage = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_manageinfo’class CloudsinoManufacturertype(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) status = models.CharField(max_length=128) class Meta: managed = False db_table = ’cloudsino_manufacturertype’class CloudsinoMemory(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) frequency = models.CharField(max_length=128) size = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) index = models.CharField(max_length=128) memoryinfo = models.ForeignKey(’CloudsinoMemoryinfo’, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_memory’class CloudsinoMemoryinfo(models.Model): max_dimmslots = models.CharField(max_length=128) mem_totalsize = models.CharField(max_length=128) memmax_capacitysize = models.CharField(max_length=128) populated_dimmslots = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_memoryinfo’class CloudsinoNetworkinfo(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) mac = models.CharField(max_length=128) speed = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) index = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_networkinfo’class CloudsinoOobnetwork(models.Model): ip = models.CharField(max_length=128) netmask = models.CharField(max_length=128) gateway = models.CharField(max_length=128) mac = models.CharField(max_length=128) ethernet_switch = models.CharField(max_length=128) swith_port = models.CharField(max_length=128) swith_mac = models.CharField(max_length=128) distribution_frame = models.CharField(max_length=128) distribution = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_oobnetwork’class CloudsinoPciecard(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) loc = models.CharField(max_length=128) online_state = models.CharField(max_length=128) conntype = models.CharField(max_length=128) bandwidth = models.CharField(max_length=128) speed = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) index = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_pciecard’class CloudsinoPowerinfo(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) model = models.CharField(max_length=128) outputpower = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) index = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_powerinfo’class CloudsinoProductnetwork(models.Model): ip = models.CharField(max_length=128) netmask = models.CharField(max_length=128) gateway = models.CharField(max_length=128) mac = models.CharField(max_length=128) os = models.CharField(max_length=128) remote_type = models.CharField(max_length=128) remote_port = models.CharField(max_length=128) ethernet_switch = models.CharField(max_length=128) swith_port = models.CharField(max_length=128) swith_mac = models.CharField(max_length=128) distribution_frame = models.CharField(max_length=128) distribution = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_productnetwork’class CloudsinoPurchasewarrantyinfo(models.Model): date_manuf = models.CharField(max_length=128) expiredate = models.CharField(max_length=128) price = models.CharField(max_length=128) purchase_order = models.CharField(max_length=128) purchase_order_name = models.CharField(max_length=128) purchase_supply = models.CharField(max_length=128) serviceagent = models.CharField(max_length=128) warrantyitem = models.CharField(db_column=’warrantyItem’, max_length=128) # Field name made lowercase. warrantyperiod = models.CharField(db_column=’warrantyPeriod’, max_length=128) # Field name made lowercase. warrantystartdate = models.CharField(db_column=’warrantyStartDate’, max_length=128) # Field name made lowercase. warrantytype = models.CharField(db_column=’warrantyType’, max_length=128) # Field name made lowercase. device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_purchasewarrantyinfo’class CloudsinoRaidinfo(models.Model): name = models.CharField(max_length=128) type = models.CharField(max_length=128) cachesize = models.CharField(max_length=128) speed = models.CharField(max_length=128) manufacturer = models.CharField(max_length=128) partnumber = models.CharField(max_length=128) serialnumber = models.CharField(max_length=128) index = models.CharField(max_length=128) device = models.ForeignKey(CloudsinoDevice, blank=True, null=True) class Meta: managed = False db_table = ’cloudsino_raidinfo’class DjangoMigrations(models.Model): app = models.CharField(max_length=255) name = models.CharField(max_length=255) applied = models.DateTimeField() class Meta: managed = False db_table = ’django_migrations’

補充知識:Django使用數據庫生成模型類

正常的開發流程

在models.py中定義模型類,要求繼承自models.Model

把應用加入settings.py文件的installed_app項

生成遷移文件

執行遷移生成表

使用模型類進行crud操作

使用數據庫生成模型類

python manage.py inspectdb > app_name/models.py

例如:

python manage.py inspectdb > booktest/models.py

以上這篇Django多數據庫配置及逆向生成model教程就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜桃视频在线观看一区二区| 国产精品一区二区三区美女| 91伊人久久| 另类亚洲自拍| aⅴ色国产欧美| 激情自拍一区| 狠狠爱成人网| 99在线观看免费视频精品观看| 久久久噜噜噜| 欧美激情三区| 久久中文精品| 国产精东传媒成人av电影| 久久国产精品免费一区二区三区| 亚洲精品伦理| 日韩激情一区二区| 欧美影院精品| 麻豆国产欧美一区二区三区| 国产欧美日韩在线观看视频| 青青国产91久久久久久| 91成人在线| 久久不见久久见中文字幕免费| 欧美少妇精品| 在线人成日本视频| 理论片午夜视频在线观看| 免费观看久久久4p| 97精品国产| 精品久久免费| 日韩视频网站在线观看| 久久亚洲在线| 亚洲精品韩国| 久久精品五月| 在线亚洲一区| 爽好多水快深点欧美视频| 亚洲国产成人精品女人| 日韩精品一级中文字幕精品视频免费观看 | 亚洲一级大片| 国产精品片aa在线观看| 国产一区二区亚洲| 亚洲黄色在线| 国产精品久久久一区二区| 日韩欧美自拍| 视频一区二区国产| 国产精品毛片视频| re久久精品视频| 美女国产精品久久久| 99精品电影| 亚洲欧美激情诱惑| 国产日产精品_国产精品毛片 | 成人免费电影网址| 天堂久久一区| 高清精品久久| 日韩精品91亚洲二区在线观看| 欧美国产中文高清| 免费观看久久av| 国产欧美一区二区色老头| 99久久视频| 亚洲精品欧美| 久久人人精品| 九九精品调教| 亚洲深夜av| 在线成人直播| 黄色不卡一区| 久久久精品五月天| 日本午夜大片a在线观看| 国产精品地址| 亚洲1区在线观看| 亚洲ww精品| 日韩欧美中文字幕在线视频| 国产精品视区| 久久麻豆精品| 另类专区亚洲| 久久av导航| 亚洲欧美日韩国产| 国产高清日韩| 亚洲精品国产偷自在线观看| 日韩精品亚洲一区二区三区免费| 欧美在线黄色| 日韩精品一区二区三区免费观看| 国产亚洲福利| 久久精品国产www456c0m| 国产精品巨作av| 欧美午夜网站| 99国产精品99久久久久久粉嫩| 日本91福利区| 国产日韩亚洲| 青青国产精品| 国产一区2区| 国产精品九九| 国产欧美69| 欧美va亚洲va日韩∨a综合色| 先锋影音久久久| 欧美国产极品| 久久精品青草| 国产欧美大片| 日本在线一区二区三区| 亚洲精品一二三区区别| 亚洲免费成人| 天堂√中文最新版在线| 日本亚洲欧美天堂免费| 欧美精品二区| 日日夜夜免费精品视频| 91精品啪在线观看国产爱臀| 亚洲www免费| 91嫩草精品| 日韩午夜视频在线| 精品在线91| 老司机精品视频网| 五月激激激综合网色播| 免费人成网站在线观看欧美高清| 欧美国产极品| 美女91精品| av一区二区高清| 精精国产xxxx视频在线野外| 国产二区精品| 精品一区二区三区在线观看视频| 欧美日韩黄网站| 夜久久久久久| 蜜臀av一区二区在线免费观看| 日韩欧美2区| 国产亚洲精品久久久久婷婷瑜伽| 久久精品国产一区二区| 视频在线观看91| 麻豆视频在线观看免费网站黄| 美女视频免费精品| 精品一区视频| 香蕉久久国产| 久久九九99| 国产综合婷婷| 欧美精品一二| 99成人在线视频| 国产精品一二| 国产精品午夜av| 久久永久免费| 国产欧美午夜| 日韩视频网站在线观看| 欧美精品高清| 国产农村妇女精品一二区| 国产精品一区二区99| 国产一区 二区| 日韩av资源网| 久久亚洲精品中文字幕蜜潮电影| 日韩高清不卡在线| 97精品视频在线看| 日韩激情中文字幕| 久久亚洲图片| 成人va天堂| 福利在线免费视频| 国产一区二区三区四区二区| 亚洲高清av| 欧美精品1区| 精品中文字幕一区二区三区av| 色黄视频在线观看| 国产美女高潮在线观看| 午夜久久久久| 中文字幕一区二区三区日韩精品 | 三级欧美在线一区| 日本一区二区免费高清| 爽爽淫人综合网网站| 日韩精品视频在线看| 美女高潮久久久| 中文一区一区三区免费在线观 | 美国三级日本三级久久99| 91麻豆精品| 久久天堂精品| 久久99性xxx老妇胖精品| 蜜桃tv一区二区三区| 国产精品115| 久久精品国产99久久| 国产精品免费大片| 一区二区国产在线| 欧美羞羞视频| 国产精品亚洲欧美日韩一区在线 | 日韩精品社区| 国产精品日本| 高清久久一区| 91成人在线网站| 国产综合亚洲精品一区二| 在线日韩成人| 久久精品二区三区| 欧美日韩精品免费观看视频完整| 欧美国产亚洲精品| 老牛影视精品| 激情91久久| 黄色av日韩| 亚洲国产日韩欧美在线| 亚洲另类黄色| 欧美午夜不卡影院在线观看完整版免费| 亚洲最新无码中文字幕久久 | 久久精品国产www456c0m| 国产女人18毛片水真多18精品| 日韩中文字幕麻豆| 特黄特色欧美大片| 伊人国产精品| 模特精品在线| 日韩有吗在线观看| 成人亚洲精品| 日本色综合中文字幕| 在线看片国产福利你懂的| 群体交乱之放荡娇妻一区二区| 亚洲综合国产|