定义属性
概述:
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

django模型相关的知识点的更多相关文章

  1. django—模型相关

    配置数据库信息 1.settings配置 DATABASES = {     "default": {         "ENGINE": "djan ...

  2. django模型中有外键关系的表删除相关设置

    0904自我总结 django模型中有外键关系的表删除相关设置 一.一对一 例如有Author.AuthorDetail两表 author = models.OneToOneField(to='Aut ...

  3. Django模型-数据库操作

    前言 前边记录的URLconf和Django模板全都是介绍页面展示的东西,也就是表现层的内容.由于Python先天具备简单而强大的数据库查询执行方法,Django 非常适合开发数据库驱动网站. 这篇开 ...

  4. django模型——数据库(二)

    模型--数据库(二) 实验简介 模型的一些基本操作,save方法用于把对象写入到数据库,objects是模型的管理器,可以使用它的delete.filter.all.order_by和update等函 ...

  5. Django模型层(2)

    <!DOCTYPE html><html lang="zh-cn"><head><meta charset="utf-8&quo ...

  6. {django模型层(二)多表操作}一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询、分组查询、F查询和Q查询

    Django基础五之django模型层(二)多表操作 本节目录 一 创建模型 二 添加表记录 三 基于对象的跨表查询 四 基于双下划线的跨表查询 五 聚合查询.分组查询.F查询和Q查询 六 xxx 七 ...

  7. django模型中的关系对应

    显然,关系数据库的力量在于将表相互关联.Django提供了定义三种最常见的数据库关系类型的方法:多对一,多对多和一对一. 在说明之前,首先来理解一下这三个概念: 多对一: 两个集合a,b;集合a中的多 ...

  8. python3之Django模型(一)

    1.模型概述 模型是关于您的数据的唯一,明确的信息来源,它包含您正在存储的数据的重要字段和行为.通常,每个模型映射到单个数据库表. 每个模型都是一个子类的python类django.db.models ...

  9. Django 模型(数据库)

    Django 模型(数据库) )         email = models.EmailField()         memo = models.TextField()   def __unico ...

随机推荐

  1. POJ 3678 Katu Puzzle (经典2-Sat)

    Katu Puzzle Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6553   Accepted: 2401 Descr ...

  2. nginx 安装SSL安全证书

    安装证书 文件说明: 1. 证书文件214051493730988.pem,包含两段内容,请不要删除任何一段内容. 2. 如果是证书系统创建的CSR,还包含:证书私钥文件214051493730988 ...

  3. 【ASP.NET】@RenderBody,@RenderPage,@RenderSection的使用

    @RenderBody @RenderBody是布局页(_Layout.cshtml)通过占位符@RenderBody占用独立部分,当创建基于此布局页的试图时,视图的内容会和布局页合并,而新创建的视图 ...

  4. Mac 重建 Spotlight 索引

    前言 最近发现很多 mac 用户反映自己的 mac 系统显示内存占用高达 200 多 Gb,可是实际上自己下载的应用程序根本没那么多,使用专业的内存扫描工具扫的结果跟系统本身显示的完全不一样.那么出现 ...

  5. Go语言开发的第一步,安装开发环境编写第一个Go程序

    关于go就不介绍了,google自己的语言.其它的百科,最近比较郁闷,处于纠结状态,不想说话,真心不想说话. 开发工具安装: 安装包下载: http://code.google.com/p/go/do ...

  6. C语言中 不定义结构体变量求成员大小

    所谓的求成员大小, 是求成员在该结构体中 用 sizeof(结构体名.结构体成员名) 求来的. 很多时候我们需要知道一个结构体成员中的某个成员的大小, 但是我们又不需要定义该结构体类型的变量(定义的话 ...

  7. label 赋值 , 隐藏 , 显示

    <label name='by_stages_number' id='by_stages_number'></label> document.getElementById(&q ...

  8. Oracle 12C -- temporal validity

    temporal validity需要在创建表的时候使用一个vaild-time维度(包含时间起始和结束) 创建有valid-time维度的表 (1)显式指定两个date-time列 SQL> ...

  9. 关于Java读取mysql中date类型字段默认值'0000-00-00'的问题

    今天在做项目过程中,查询一个表中数据时总碰到这个问题:      java.sql.SQLException:Value '0000-00-00' can not be represented as ...

  10. js 什么是深拷贝问题?

    一.什么是值类型? 二.什么是引用类型? 三.使用ES Next新特性带来的 Object.assign 方法 和 扩展运算符: 四.Object.assign 方法 和 扩展运算符的 “深入浅出” ...