django中实现表结构,一对一,一对多,多对多

这篇博客通过学生、学院和课程的例子,详细阐述了在Django中如何实现表结构的一对一、一对多和多对多关系。学生表与学生详情表建立一对一关系,学生表与学院表是一对多,而学生表与课程表则是多对多关系,其中多对多关系使用Django自动生成的中间表。最后展示了在MySQL数据库中的实际表结构。
摘要由CSDN通过智能技术生成

这里拿学生选课和选学校来举例子

一共有4张表(中间表先不算)

  • 1.学生表
  • 2.学生详情表
  • 3.课程表
  • 4.学院表

关系有3种

  • 一对一

  • 一对多

  • 多对多

学生表和学生详情表构成一对一关系(一个学生对应一个学生详情)
学生表和学院表构成一对多关系(一个学生只能选一个学院,一个学院可以选多个学生)
学生表和课程表构成多对多关系(一个学生可以选多门课,一个课程可以包含多个学生)

1.学院表(与学生表构成一对多)

# 朴实无华的学院表
class Department(models.Model):
    d_id = models.AutoField(primary_key=True)
    d_name = models.CharField(max_length=30)

2.学生表

学生表

class Student(models.Model):
    s_id = models.AutoField(primary_key=True)
    s_name = models.CharField(max_length=30)
    department = models.ForeignKey('Department',on_delete=models.CASCADE) # 级联删除
    course = models.ManyToManyField('Course')

3.课程表(与学生表构成多对多,但是要一个中间表(django自动生成))

# 朴实无华的课程表
class Course(models.Model):
    c_id = models.AutoField(primary_key=True)
    c_name = models.CharField(max_length=30)

4.学生详情表(与学生表构成一对一)

class Stu_detail(models.Model):
    stu_detail = models.OneToOneField('Student',on_delete=models.CASCADE)
    age = models.IntegerField()
    sex = models.CharField(max_length=30,null=True)

最后看一下mysql数据库中的表结构

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值