• django模型:字段和选项


    https://blog.csdn.net/iloveyin/article/details/44852645
    一、常用字段
    1、字段类型
    使用时需要引入django.db.models包,字段类型如下
    AutoField:自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性
    BooleanField:布尔字段,值为True或False
    NullBooleanField:支持Null、True、False三种值
    CharField(max_length=字符长度):字符串 参数max_length表示最大字符个数
    TextField:大文本字段,一般超过4000个字符时使用
    IntegerField:整数
    DecimalField(max_digits=None, decimal_places=None):十进制浮点数
    参数max_digits表示总位数
    参数decimal_places表示小数位数
    FloatField:浮点数
    DateField[auto_now=False, auto_now_add=False]):日期
    参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为false
    参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为false
    参数auto_now_add和auto_now是相互排斥的,组合将会发生错误
    TimeField:时间,参数同DateField
    DateTimeField:日期时间,参数同DateField
    FileField:上传文件字段
    ImageField:继承于FileField,对上传的内容进行校验,确保是有效的图片

    2、关系字段类型
    关系型数据库的关系包括三种类型:
    ForeignKey:一对多,将字段定义在多的一端中
    ManyToManyField:多对多,将字段定义在两端中
    OneToOneField:一对一,将字段定义在任意一端中
    可以维护递归的关联关系,使用'self'指定,详见“关联对象”

    二、常用选项
    1、选项
    通过选项实现对字段的约束,选项如下:
    max_length:为CharField型字段设置最大长度。
    null:如果为True,表示允许为空,默认值是False
    default:默认值

    db_column:string 值,指定当前列在数据库中的名字,不设置,将自动采用model字段名;

    verbose_name:设置此字段在admin界面上的显示名称。(这个功能和list_display属性类似了,优先显示verbose_name)

    blank:如果为True,则该字段允许为空白,默认值是False
    对比:null是数据库范畴的概念,blank是表单验证证范畴的
    db_column:字段的名称,如果未指定,则使用属性的名称
    db_index:若值为True, 则在表中会为此字段创建索引,默认值是False
    primary_key:若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用
    unique:如果为True, 这个字段在表中必须有唯一值,默认值是False

    2、元选项

    (1)修改表名

    数据表的默认名称为
    <app_name>_<model_name>
    例:
    booktest_bookinfo
    在模型类中定义类Meta,用于设置元信息,如使用db_table自定义表的名字

    from django.db import models
    
    
    class TbPassage234(models.Model):
        title = models.CharField(max_length=225)
        author = models.CharField(max_length=50,null=True,verbose_name='姓 名')
        pubtime = models.DateTimeField(null=True)
        sort = models.CharField(max_length=50,null=True)
        content = models.TextField(null=True)
        parse_time = models.DateTimeField(null=True,max_length=0)
        url_path = models.CharField(max_length=225,null=True)
        level_id = models.IntegerField(null=True)
        isDelete = models.BooleanField(default=False)#逻辑删除
        
        class Meta:#元类
            db_table = 'tb_passage234' #自定义表名
    

      

    (2)修改字段名、设置打印显示名称

    # 定义图书模型类BookInfo
    class BookInfo(models.Model):
        btitle = models.CharField(max_length=20)  # 图书名称
        bpub_date = models.DateField()  # 发布日期
        bread = models.IntegerField(default=0)  # 阅读量
        bcommet = models.IntegerField(default=0)  # 评论量
        isDelete = models.BooleanField(default=False, db_column="bisDelete")  # 逻辑删除。修改字段名称。字段名isDelete修改为bisDelete
    
        class Meta:  # 元信息类
            db_table = 'bookinfo'  # 修改表的名称。表名booktest_bookinf修改为bookinfo
    
        def __str__(self):
            return self.btitle   # 打印时显示名称
    

      

    清空迁移操作
    https://blog.csdn.net/jianjianblog/article/details/52772591

  • 相关阅读:
    css3 实现水平或垂直布局
    css div 细边框
    css scroll bug
    F和弦大横按
    简单分析beyond作曲
    [编织消息框架][设计协议]优化long,int转换
    nginx 限制ip
    nginx注册成服务
    nginx 添加win 服务
    sqlserver 使用维护计划备份
  • 原文地址:https://www.cnblogs.com/andy9468/p/8810059.html
Copyright © 2020-2023  润新知