model(模型) 是学习 django 最重要的知识,模型设计的好坏直接影响到你后期的开发,模型的设计只能靠自身经验提高。模型准确且唯一的描述了数据,包含您储存的数据的重要字段和行为。比如一个学生系统需要展示学生的姓名、年龄、分数成绩等信息,这些数据就要保存到数据库中。
我前面说过,简单点的 web 开发就是对数据库进行增删改查操作,查询数据,新增数据,修改数据,删除数据 。当你定义好的模型信息,执行 python manager.py makemigtations 会自动生成数据库同步脚本,模型字段和数据库表生成映射关系(这个时候并没有操作数据库),执行 python manager.py migrate 后会自动执行数据库同步脚本,对数据库表结构进行更改操作。
每个模型都是一个 Python 的类,这些类继承 django.db.models.Model
模型类的每个属性都相当于一个数据库的字段。利用这些,Django 提供了一个自动生成访问数据库的 API,django 可以使用 ORM 操作数据库,就算你不熟悉 SQL 语法,也能很熟练的操作数据库,而且就算你后期换了数据库,项目中的关于数据库操作的代码不用更改。
假如,你要给一张表的每列字段设置字符类型,比如有的字段是char类型,有的是int类型,django中的模型字段类型的作用就是上面提到的设置数据表的数据类型。常见的有 字符串类型 CharField 、文本类型 TextField、整型 IntegerField、浮点型 DecimalField 、日期类型 DateTimeField,表示两张表的外键关系 ForeignKey(一对多)一个班级有多个学生,多对多是 ManyToManyField。
以学生表(Student),班级表(Class)表为例,一个班级有多个学生,详细的字段解释见下图:
# CharField为字符串类型,必须有max_length设置最大长度,verbose_name在django后 台显示该英文字段的中文意思 # IntegerField整型 # DecimalField浮点型,max_digits=5表示整数部分和小数位数之和不大于5,decimal_places表示小数的最大位数,null=True表示字段可以为空,blank=True表示在admin后台中该数据栏可以为空 # EmailField该字段必须符合邮箱格式 # TextField 字段为文本类型,长度没有限制 # DateTimeField为日期类型,auto_now_add=True该条数据创建的时间,数据更新时,时间数值不变 # auto_now=True该条数据创建的时间,数据更新时,时间数值也会改变 # ForeignKey一对多外键,第一个参数位你要关联的数据表,比如一个班级有多个学生,就属于一对多,外键要放到"多"的那张表,related_name是对外键取别名,常用在django的orm反向查询中使用
项目源地址:https://github.com/zxycode-2020/django_tutrital2/tree/master
欢迎点击转发、在看。有问题可以或者不懂的可以留言交流。