數據庫表反向生成(二) Django ORM inspectdb

前一篇咱們說了,mybatis-generator反向生成代碼。html

這裏咱們開始說如何在django中反向生成mysql model代碼。 python

咱們在展現django ORM反向生成以前,咱們先說一下怎麼樣正向生成代碼。mysql

正向生成,指的是先建立model.py文件,而後經過django內置的編譯器,在數據庫如mysql中建立出符合model.py的表。sql

反向生成,指的是先在數據庫中create table,而後經過django內置的編譯器,生成model代碼。數據庫

 

一、準備工做django

建立django工程以及appsession

建立django工程,名字是helloworldmybatis

django-admin.py startproject helloworld

建立app,名字是testapp

python manage.py startapp hello  

配置數據庫spa

在settings.py的INSTALLED_APPS配置app

# Application definition  
  
INSTALLED_APPS = [  
    'django.contrib.admin',  
    'django.contrib.auth',  
    'django.contrib.contenttypes',  
    'django.contrib.sessions',  
    'django.contrib.messages',  
    'django.contrib.staticfiles',  
    'hello',  
]  

在settings.py中配置數據庫

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'big_data',
        'USER': 'root',
        'PASSWORD': '1234',
        'HOST': '10.93.84.53',
        'PORT': '3306',
    }
}

 

二、正向生成

在hello app的目錄下建立model.py

from django.db import models

class AlarmGroup(models.Model):
    group_name = models.CharField(primary_key=True, max_length=250)
    group_des = models.TextField(blank=True, null=True)
    members = models.TextField(blank=True, null=True)
    timestamp = models.DateTimeField()

執行命令正向生成

python manage.py makemigrations
python manage.py migrate

能夠到配置的數據庫中,查看建立成功的表

 

三、反向生成

如今數據庫中建立表

CREATE TABLE `alarm_group` (
  `group_name` varchar(250) NOT NULL,
  `group_des` blob,
  `members` blob,
  `timestamp` datetime NOT NULL,
  `on_duty` blob,
  `leader` blob,
  PRIMARY KEY (`group_name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

而後執行命令,生成model.py代碼

python manage.py inspectdb

生成的代碼model.py以下

class AlarmGroup(models.Model):
    group_name = models.CharField(primary_key=True, max_length=250)
    group_des = models.TextField(blank=True, null=True)
    members = models.TextField(blank=True, null=True)
    timestamp = models.DateTimeField()

    class Meta:
        managed = False
        db_table = 'alarm_group'

這裏面的db_table映射了數據庫中的表名。

相關文章
相關標籤/搜索