django学习-数据表关系

文章目录

      • 一、数据表关系
        • [1. 一对一关系](#1. 一对一关系)
        • [2. 一对多关系](#2. 一对多关系)
        • [3. 多对多关系](#3. 多对多关系)

一、数据表关系

一个模型对应数据库的一张数据表,但是每张数据表之间是可以存在外键关联的,表与表之间有3种关联:一对一、一对多和多对多。

1. 一对一关系

一对一关系存在于两张数据表中,第一张表的某一行数据只与第二张表的某一行数据相关,同时第二张表的某一行数据也只与第一张表的某一行数据相关,这种表关系被称为一对一关系。

在模型中可以通过OneToOneField来构建数据表的一对一关系,代码如下:

复制代码
# models.py

class UserProfile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)  # 此处进行了用户一对一关系对应
    bio = models.TextField(max_length=500, blank=True)
    location = models.CharField(max_length=100, blank=True)
    birth_date = models.DateField(null=True, blank=True)

    def __str__(self):
        return f'{self.user.username}\'s profile'

class User(models.Model):
    username = models.CharField(max_length=100)
    email = models.EmailField()
    date_joined = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.username
2. 一对多关系

一对多关系存在于两张或两张以上的数据表中,第一张表的某一行数据可以与第二张表的一到多行数据进行关联,但是第二张表的每一行数据只能与第一张表的某一行进行关联。

这种表关系在日常开发中最为常见。在模型中可以通过ForeignKey来构建数据表的一对多关系,代码如下:

复制代码
# models.py

class Author(models.Model):
    name = models.CharField(max_length=100)

    def __str__(self):
        return self.name

class Book(models.Model):
    title = models.CharField(max_length=200)
    author = models.ForeignKey(Author, on_delete=models.CASCADE)  # 此处与作者模型建立了一对多关系
    published_date = models.DateField()

    def __str__(self):
        return self.title
3. 多对多关系

多对多关系存在于两张或两张以上的数据表中,第一张表的某一行数据可以与第二张表的一到多行数据进行关联,同时第二张表中的某一行数据也可以与第一张表的一到多行数据进行关联。

注意: 数据表之间创建多对多关系时,只需在项目里定义两个模型对象即可,在执行数据迁移时,Django自动生成3张数据表来建立多对多关系。

在模型中可以通过ManyToManyField来构建数据表的多对多关系,代码如下:

复制代码
# models.py

class Student(models.Model):
    name = models.CharField(max_length=100)

    def __str__(self):
        return self.name

class Course(models.Model):
    name = models.CharField(max_length=100)
    students = models.ManyToManyField(Student)  # 在这个地方建立了与student模型的多对多关系

    def __str__(self):
        return self.name

综上所述,模型之间的关联是由OneToOneFieldForeignKeyManyToManyField外键字段实现的,每个字段设有特殊的参数,常见参数说明如下:

参数 说明
to 必选参数,关联的模型名称。
on_delete 必选参数,设置数据的删除模式,删除模型包括:CASCADE、PROTECT、SET_NULL、SET_DEFAULT、SET和DO_NOTHING。
limit_choices_to 设置外键的下拉框选项,用于模型表单和Admin后台系统。
related_name 用于模型之间的关联查询,如反向查询。
related_query_name 设置模型的查询名称,用于filter或get查询,若设置参数related_name,则以该参数为默认值,若没有设置,则以模型名称的小写为默认值。
db_table 仅限于ManyToManyField,为管理和存储多对多关系的数据表设置表名称。
相关推荐
DCTANT26 分钟前
【原创】国产化适配-全量迁移MySQL数据到OpenGauss数据库
java·数据库·spring boot·mysql·opengauss
sealaugh3228 分钟前
aws(学习笔记第四十八课) appsync-graphql-dynamodb
笔记·学习·aws
水木兰亭1 小时前
数据结构之——树及树的存储
数据结构·c++·学习·算法
鱼摆摆拜拜1 小时前
第 3 章:神经网络如何学习
人工智能·神经网络·学习
aha-凯心1 小时前
vben 之 axios 封装
前端·javascript·学习
AI、少年郎3 小时前
Oracle 进阶语法实战:从多维分析到数据清洗的深度应用(第四课)
数据库·oracle
赤橙红的黄3 小时前
自定义线程池-实现任务0丢失的处理策略
数据库·spring
DataGear3 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化
weixin_438335403 小时前
分布式锁实现方式:基于Redis的分布式锁实现(Spring Boot + Redis)
数据库·redis·分布式
码不停蹄的玄黓3 小时前
MySQL Undo Log 深度解析:事务回滚与MVCC的核心功臣
数据库·mysql·undo log·回滚日志