Django多数据库配置及逆向生成model教程


Posted in Python onMarch 28, 2020

在项目中我们每个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_MAPPING

DATABASE_MAPPING = DATABASE_APPS_MAPPING


class 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_literals

from django.db import models


class 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教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中实现精确的浮点数运算详解
Nov 02 Python
Python使用pandas处理CSV文件的实例讲解
Jun 22 Python
Python使用Selenium模块模拟浏览器抓取斗鱼直播间信息示例
Jul 18 Python
python实现决策树分类
Aug 30 Python
Python中GeoJson和bokeh-1的使用讲解
Jan 03 Python
python 利用文件锁单例执行脚本的方法
Feb 19 Python
python实现趣味图片字符化
Apr 30 Python
python kafka 多线程消费者&手动提交实例
Dec 21 Python
Python OrderedDict字典排序方法详解
May 21 Python
Keras之fit_generator与train_on_batch用法
Jun 17 Python
python读写数据读写csv文件(pandas用法)
Dec 14 Python
Python实现Appium端口检测与释放的实现
Dec 31 Python
后端开发使用pycharm的技巧(推荐)
Mar 27 #Python
如何基于python3和Vue实现AES数据加密
Mar 27 #Python
python小程序基于Jupyter实现天气查询的方法
Mar 27 #Python
Python实现的北京积分落户数据分析示例
Mar 27 #Python
Pyspark获取并处理RDD数据代码实例
Mar 27 #Python
Python Django中的STATIC_URL 设置和使用方式
Mar 27 #Python
Python爬虫爬取、解析数据操作示例
Mar 27 #Python
You might like
自动检查并替换文本框内的字符
2006/06/30 Javascript
一些常用的Javascript函数
2006/12/22 Javascript
js 纯数字不重复排列的另类方法
2010/07/17 Javascript
精通Javascript系列之数值计算
2011/06/07 Javascript
禁用Tab键JS代码兼容Firefox和IE
2014/04/18 Javascript
快速掌握Node.js事件驱动模型
2016/03/21 Javascript
JavaScript编写Chrome扩展实现与浏览器的交互及时间通知
2016/05/16 Javascript
封装获取dom元素的简单实例
2016/07/08 Javascript
Vue实现百度下拉提示搜索功能
2017/06/21 Javascript
微信小程序 sha1 实现密码加密实例详解
2017/07/06 Javascript
JavaScript轮播停留效果的实现思路
2018/05/24 Javascript
基于vue实现web端超大数据量表格的卡顿解决
2019/04/02 Javascript
VSCode使用之Vue工程配置eslint
2019/04/30 Javascript
jquery登录的异步验证操作示例
2019/05/09 jQuery
微信小程序云开发之模拟后台增删改查
2019/05/16 Javascript
js刷新页面location.reload()用法详解
2019/12/09 Javascript
微信小游戏中three.js离屏画布的示例代码
2020/10/12 Javascript
Python网络爬虫实例讲解
2016/04/28 Python
python爬虫获取新浪新闻教学
2018/12/23 Python
Python3最长回文子串算法示例
2019/03/04 Python
浅谈python编译pyc工程--导包问题解决
2019/03/20 Python
python3发送邮件需要经过代理服务器的示例代码
2019/07/25 Python
PyQt5基本控件使用之消息弹出、用户输入、文件对话框的使用方法
2019/08/06 Python
Python基本语法之运算符功能与用法详解
2019/10/22 Python
爬虫代理池Python3WebSpider源代码测试过程解析
2019/12/20 Python
在ipython notebook中使用argparse方式
2020/04/20 Python
你不知道的葡萄干处理法、橙蜜处理法、二氧化碳酵母法
2021/03/17 冲泡冲煮
澳大利亚宠物商店:Petbarn
2017/11/18 全球购物
施工资料员岗位职责
2014/01/06 职场文书
单位创先争优活动方案
2014/01/26 职场文书
教师职称自我鉴定
2014/02/12 职场文书
自主招生教师推荐信
2014/05/10 职场文书
贪污检举信范文
2015/03/02 职场文书
大学优秀学生主要事迹材料
2015/11/04 职场文书
Nginx优化服务之网页压缩的实现方法
2021/03/31 Servers
Java面试题冲刺第十九天--数据库(4)
2021/08/07 Java/Android