数据库表反向生成 Django ORM inspectdb

数据库表反向生成(二) Django ORM inspectdb

这里我们开始说如何在django中反向生成mysql model代码。 

我们在展示django ORM反向生成之前,我们先说一下怎么样正向生成代码。

正向生成,指的是先创建model.py文件,然后通过django内置的编译器,在数据库如mysql中创建出符合model.py的表。

反向生成,指的是先在数据库中create table,然后通过django内置的编译器,生成model代码。

 

1、准备工作

创建django工程以及app

创建django工程,名字是helloworld

django-admin.py startproject helloworld

创建app,名字是test

python manage.py startapp hello  

配置数据库

在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',
    }
}
复制代码
复制代码

 

2、正向生成

在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

可以到配置的数据库中,查看创建成功的表

 

3、反向生成

现在数据库中创建表

复制代码
复制代码
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映射了数据库中的表名。

python manage.py inspectdb > app01\models.py

坑!!! windows下为‘\’

posted @   import*  阅读(579)  评论(0编辑  收藏  举报
编辑推荐:
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
阅读排行:
· 2025成都.NET开发者Connect圆满结束
· 后端思维之高并发处理方案
· 千万级大表的优化技巧
· 在 VS Code 中,一键安装 MCP Server!
· 10年+ .NET Coder 心语 ── 继承的思维:从思维模式到架构设计的深度解析
点击右上角即可分享
微信分享提示