Django+Vue3前后端分离学习(三)(创建表的注意事项)

复制代码
class OADepartment(models.Model):
    name = models.CharField(max_length=100)
    intro = models.CharField(max_length=200)
    # leader
    leader = models.OneToOneField(OAUser, null=True, on_delete=models.SET_NULL, related_name='leader_department', related_query_name='leader_department')
    # manager
    manager = models.ForeignKey(OAUser, null=True, on_delete=models.SET_NULL, related_name='manager_departments', related_query_name='manager_departments')

models.OneToOneField()实现一对一的关联;

models.ForeignKey()实现一对多的关联;

models.ManyToManyField()实现多对多的关联。

related_name参数用于指定反向关系的名称。当你在一个模型中使用ForeignKey或OneToOneField等关系字段指向另一个模型时,Django会自动为你生成一个反向关系。这个反向关系的名称就是你在关系字段上指定的related_name。

related_query_name参数用于指定在查询时使用的名称。当你使用一个模型进行查询时,Django会自动为你生成相关的查询。这些查询的名称就是你在关系字段上指定的related_query_name。

相关推荐
DEMO派4 分钟前
首页图片懒加载实现方案解析
前端
用户952081611798 分钟前
百度地图MapVThree Editor:地图编辑
前端
大猫和小黄10 分钟前
若依微服务Cloud中Quartz-Job模块适配OpenGauss数据库
数据库·微服务·opengauss·quartz·定时任务·若依·job
奔跑的小十一25 分钟前
ShardingSphere-JDBC 开发手册
java·数据库
lkbhua莱克瓦2425 分钟前
基础-MySQL概述
java·开发语言·数据库·笔记·mysql
程序员龙语26 分钟前
CSS 文本样式与阴影属性
前端·css
姓蔡小朋友28 分钟前
MySQL增删查改、多表查询
数据库·mysql
龘龍龙30 分钟前
Python基础学习(七)
开发语言·python·学习
LYFlied35 分钟前
【每日算法】LeetCode 152. 乘积最大子数组(动态规划)
前端·算法·leetcode·动态规划
Knight_AL39 分钟前
Maven <dependencyManagement>:如何在多模块项目中集中管理依赖版本
java·数据库·maven