Django中反向生成models

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

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

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

一 準備工做

建立django工程以及app數據庫

建立django工程,名字是helloworlddjango

django-admin.py startproject helloworld

建立app,名字是testsession

python manage.py startapp hello

配置數據庫app

在settings.py的INSTALLED_APPS配置appspa

# 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中配置數據庫code

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

二 正向生成

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

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

三 反向生成ORM

先在數據庫中建立表

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`) ) ENGIN

而後執行命令,生成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'

將代碼導入到項目中

python manage.py inspectdb > hello/models.py

根據表名生成

python manage.py inspectdb school_schoolinfo
相關文章
相關標籤/搜索