Django 根据数据库自动生成模型
2020-06-06 本文已影响0人
安和然
具体用法,在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