• django模型相关的知识点


    定义属性
        概述:
            django根据属性的类型确定以下信息
                当前选择的数据库支持字段的类型
                渲染管理表单时使用的默认html控件
                在管理站点最低限度的验证
    
            django会为表增加自动增长的主键列,每个模型只能有一个主键列,如
            果使用选项设置某属性为主键列后,则django不会再生成默认的主键列
    
            属性命名限制
                遵循标识符规则,且变量不能与Python保留字相同
                由于django的查询方式,不允许使用连续的下划线
    
        库
            定义属性时,需要字段类型,字段类型被定义在django.db.models.fields目录下,
            为了方便使用,被导入到django.db.models中
    
            使用方式
                导入: from django.db import models
                通过 models.Field创建字段类型的对象,赋值给属性
    
        逻辑删除
            对于重要类型都做逻辑删除,不做物理删除,实现方法是定义idDelete属性,
            类型为BooleanField,默认值为False
    
        字段类型
            autoField
                一个根据实际ID自动增长的IntegerField,通常不指定,
                如果不指定,一个主键字段将自动添加到模型中
    
            CharField(max_length=字符长度)
                字符串,默认的表彰样式是TextInput
    
            TextField
                大文本字段,一般超过4000时使用,默认的表单控件是Textarea
    
            IntegerField
                整数
    
            DecimalField(max_digits=None, decimal_places=None)
                使用Python的Decimal实例表示的十进制浮点数
                参数说明
                    DecimalField.max_digits
                        位数总数
                    DecimalField.decimal_places
                        小数点后的数字位置
    
            FloatField
                使用Python的float实例来表示的浮点数
    
            BooleanField
                True/False 字段,此字段的默认表彰控制是CheckboxInput
    
            NullBooleanField
                支持 Null, True, False 三种值
    
            DateField([auto_now=False, auto_now_add=False])
                使用Python的datetime.date实例表示的日期
                参数说明:
                    DateField.auto_now
                        每次保存对象时,自动设置该字段为当前时间,用于“最后一次修改”
                        的时间戳,它总是使用当前日期,默认为 False
                    DateField.auto_now_add
                        当前对象第一次被创建时自动设置当前时间,用于创建的时间戳,
                        它总是使用当前日期,默认为 False
                说明
                    该字段默认对应的表单控件是一个TextInput.在管理员站点添加了一个
                    JavaScript写的日历控件,和一个“Today”的快捷按钮,包含了一个额外
                    的invalid_date错误消息键
                注意
                    auto_now_add, auto_now, and default 这些设置是相互排斥的,他们之间
                    的任何组合将会发生错误的结果
    
            TimeField
                使用Python的datetime.time实例表示的时间,参数同DateField
    
            DateTimeField
                使用Python的datetime
                datetime实例表示的日期和时间,参数同DateField
    
            FileField
                一个上传文件的字段
    
            ImageField
                继承了FileField的所有属性和方法,但对上传的对象进行校验,
                确保它是一个有效的image
    
        字段选项
            概述
                通过字段选项,可以实现对字段的约束
                在字段对象中通过关键字参数指定
    
            null
                如果为True,Django将空值以NULL存储在数据库中,默认值为 False
    
            blanke
                如果为True,则该字段允许为空白,默认值为 False
    
            注意
                null是数据库范畴的概念,blank是表彰验证范畴的概念
    
            db_column
                字段的名称,如果未指定,则使用属性的名称
    
            db_index
                若值为 True,则在表中会为此字段创建索引
    
            default
                默认值
    
            primary_key
                若为 True,则该字段会成为模型的主键字段
    
            unique
                如果为 True,这个字段在表中必须有唯一值
    
        关系
            分类
                ForeignKey:一对多,将字段定义在多的端中
                ManyToManyField:多对多,将字段定义在两端中
                OneToOneField:一对一,将字段定义在任意一端中
    
            用一访问多
                格式
                    对象.模型类小写_set
                示例
                    grade.students_set
    
            用一访问一
                格式
                    对象.模型类小写
                示例
                    grade.studnets
    
            访问id
                格式
                    对象.属性_id
                示例
                    student.sgrade_id
    
  • 相关阅读:
    T-sql for xml path使用
    解决 SQL Server2012附加出错的问题
    安装应用程序 报“ 997 重叠 I/O 操作在进行中”错解决办法
    使用QQ互联登录应用
    monogdb windows环境下 安装及使用简单示例
    idle-实现清屏
    colorscheme-如何vim颜色风格
    android-从官网下拉源码(ubuntu)
    hq-源码编译
    文件目录进入终端
  • 原文地址:https://www.cnblogs.com/superxuezhazha/p/10355606.html
Copyright © 2020-2023  润新知