美文网首页
Django 根据数据库自动生成模型

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

作者: 安和然 | 来源:发表于2020-06-06 22:31 被阅读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
    

    相关文章

      网友评论

          本文标题:Django 根据数据库自动生成模型

          本文链接:https://www.haomeiwen.com/subject/yovozhtx.html