Django模型基础第三节:常用的模型字段类型以及表关系的实现

常用的字段类型映射关系:

int ---------------IntegetField
varchar------------------CharField
longtext------------TextField
date--------------DateField
datetime----------------DateTimeField

常用的字段类型:

  1. IntegerField : 整型,映射到数据库中的int类型。
  2. CharField: 字符类型,映射到数据库中的varchar类型,通过max_length指定最大长度。
  3. TextField: 文本类型,映射到数据库中的text类型。
  4. BooleanField: 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递True/False进去。如果要可以为空,则用NullBooleanField。
  5. DateField: 日期类型,没有时间。映射到数据库中是date类型,
    在使用的时候,可以设置DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置DateField.auto_now_add当对象第一次被创建时自动设置当前时间。
  6. DateTimeField: 日期时间类型。映射到数据库中的是datetime类型,
    在使用的时候,传递datetime.datetime()进去。

Field的常用参数:

primary_key: 指定是否为主键。
unique: 指定是否唯一。
null: 指定是否为空,默认为False。
blank: 等于True时form表单验证时可以为空,默认为False。
default: 设置默认值。
DateField.auto_now: 每次修改都会将当前时间更新进去,只有调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及TimModel.save()方法才会调用e类才有的。
需要save方法储存
DateField.auto_now_add: 第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

表关系的实现:

一对多------外键--------ForeignKeyField
一对一-----外键+唯一键--------OneToOneField
多对多--------关联表:外键+联合唯一------ManyToManyField

表关系图:

在这里插入图片描述

表关系的例子:

学院信息表—一对多----学生信息表
学生信息表----一对一----学生详细信息表
课程表----多对多----学生信息表

#学院表
class Department(models.Model):
    d_id = models.AutoField(primary_key=True)
    d_name = models.CharField(max_length=20)
    def __str__(self):
        return 'Department:d_id:%s, d_name:%s'%(self.d_id,self.d_name)


#学生表

class Student(models.Model):
    s_id =models.AutoField(primary_key=True)
    s_name = models.CharField(max_length=20)
    department = models.ForeignKey('Department',on_delete=models.CASCADE)
    course = models.ManyToManyField('Course')

    def __str__(self):
        return 'Student:s_id:%s, s_name:%s '%(self.s_id,self.s_name)
#学生课程表
class Course(models.Model):
    c_id = models.AutoField(primary_key=True)
    c_name = models.CharField(max_length=20)

    def __str__(self):
        return 'Course:c_id:%s, c_name:%s '%(self.c_id,self.c_name)

#学生详情表
class Detail(models.Model):

    s_id = models.OneToOneField('Student',on_delete=models.CASCADE)
    age = models.IntegerField()
    gender = models.BooleanField(default=True)

    def __str__(self):
        return 'Detail:s_id:%s, age:%s, gender:%s '%(self.s_id,self.age,self.gender)

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_42662411/article/details/104631707