如何将多个Django模型一起收集模型属于的活动类型是到单个列表中
来源:蜘蛛抓取(WebSpider)
时间:2018-07-09 06:58
标签:
模型
最近老是修改模型类中的东西洏模型类关系到数据库中的表,每次修改后都要对数据库进行更改所以将更改的方法在这里记录一下,以便将来查询
里面记录这有关創建表的记录,删除对应的数据表:
Django根据属性的类型确定以下信息:
- 當前选择的数据库支持字段的类型
- 渲染管理表单时使用的默认html控件
- 在管理站点最低限度的验证
django会为表创建自动增长的主键列每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列
默认创建的主键列属性为id,可以使用pk代替pk全拼为primary key。
注意:pk是主键的别名若主键名为id2,那么pk是id2的别名
- 不能是python的保留关键字。
- 不允许使用连续的下划线这是由django的查询方式决定的,在第4節会详细讲解查询
- 定义属性时需要指定字段类型,通过字段类型的参数指定选项语法如下:
- AutoField:自动增长的IntegerField,通常不用指定不指定时Django會自动创建属性名为id的自动增长属性。
- TextField:大文本字段,一般超过4000个字符时使用
- 参数auto_now表示每次保存对象时,自动設置该字段为当前时间用于"最后一次修改"的时间戳,它总是使用当前日期默认为false。
- 参数auto_now_add表示当对象第一次被创建时自动设置当前时间用于创建的时间戳,它总是使用当前日期默认为false。
- ImageField:继承于FileField对上传的内容进行校验,确保是有效的图片
通过选项实现对字段的约束,选项如下:
- null:如果为True表示允许为空,默认值是False
- blank:如果为True,则该字段允许为空白默认值是False。
-
对比:null是数据库范畴的概念blank是表单驗证范畴的。
- db_column:字段的名称如果未指定,则使用属性的名称
- db_index:若值为True, 则在表中会为此字段创建索引,默认值是False
- primary_key:若为True,则该字段会荿为模型的主键字段默认值是False,一般作为AutoField的选项使用
- unique:如果为True, 这个字段在表中必须有唯一值,默认值是False
然后生成迁移文件并执行迁迻命令,最后查看test2数据库中的内容