Django 根据数据库自动生成模型

具体用法,在Django项目下

python manage.py inspecdb tablename

目标

在Django中,我们通过models.py来创建新的数据库表。
但是往往有时候,我们需要利用到之前的已经设计好的数据库,数据库中提供了设计好的多种表单。那么这时如果我们再通过models.py再来设计就会浪费很多的时间。所幸Django为我们提供了inspecdb的方法。他的作用即使根据已经存在对的mysql数据库表来反向映射结构到models.py中.

示例

生成App,并加入setting

python manage.py startapp car

数据库已存在car表格

python manage.py inspecdb car

生成一个model的示例

from django.db import models


class Car(models.Model):
    id = models.IntegerField(blank=True, null=True)
    datetime = models.DateTimeField()
    car_number = models.CharField(max_length=20)
    totle_mile = models.IntegerField(blank=True, null=True)
    month_mile = models.IntegerField(blank=True, null=True)
    qiyou = models.IntegerField(blank=True, null=True)
    caiyou = models.IntegerField(blank=True, null=True)
    qiyou_cost = models.IntegerField(blank=True, null=True)
    caiyou_cost = models.IntegerField(blank=True, null=True)
    fix_cost = models.IntegerField(blank=True, null=True)

    class Meta:
        managed = False
        db_table = 'car'

将以上内容复制到car/model 下 并进行修改完善

from django.db import models

class Car(models.Model):
    datetime = models.DateField(verbose_name='日期')
    car_number = models.CharField(max_length=20,verbose_name='车牌号')
    totle_mile = models.FloatField(blank=True, null=True,verbose_name='总里程')
    month_mile = models.FloatField(blank=True, null=True,verbose_name='当月里程')
    qiyou = models.FloatField(blank=True, null=True,verbose_name='汽油用量')
    caiyou = models.FloatField(blank=True, null=True,verbose_name='柴油用量')
    qiyou_cost = models.FloatField(blank=True, null=True,verbose_name='汽油金额')
    caiyou_cost = models.FloatField(blank=True, null=True,verbose_name='柴油金额')
    fix_cost = models.FloatField(blank=True, null=True,verbose_name='维修费用')

    class Meta:
        managed = False
        db_table = 'car'
        verbose_name = '车辆能耗管理'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.car_number

运行

python manage.py makemigrations car
python manage.py migrate car

你可能感兴趣的:(Django 根据数据库自动生成模型)