Django model 外键 xx_id field

子model:portrait/ability_score/views.py

python 复制代码
from django.db import models


# Create your models here.
class AbilityScore(models.Model):
    index = models.AutoField(db_column="Index", auto_created=True, primary_key=True)
    employee_id = models.CharField(db_column="EmployeeID", max_length=10, default='')
    ability = models.ForeignKey(to='ability_standard.AbilityStandard', on_delete=models.CASCADE,
                                db_column="AbilityID", default=None)
    approved_value = models.CharField(db_column="ApprovedValue", max_length=2, default='')
    upcoming_value = models.CharField(db_column="UpcomingValue", max_length=2, default='')
    create_time = models.DateTimeField(db_column="CreateTime", auto_now_add=True)
    update_time = models.DateTimeField(db_column="UpdateTime", auto_now=True)

    class Meta:
        managed = True
        db_table = 'ability_score'
        constraints = [
            models.UniqueConstraint(fields=['employee_id', 'ability_id'], name='unique_employee_id_ability_id')
        ]

子表:ability_score

父model:portrait/ability_standard/models.py

python 复制代码
from django.db import models

# Create your models here.
class AbilityStandard(models.Model):
    ability_id = models.BigAutoField(db_column='AbilityID', primary_key=True)  # Field name made lowercase.
    department = models.CharField(db_column='Department', max_length=50,default='',
                              db_comment='部门')  # Field name made lowercase.
    ......

注意点:

  • 通过ability = models.ForeignKey(to='ability_standard.AbilityStandard', on_delete=models.CASCADE, db_column="AbilityID", default=None)创建外键时会自动生成一个ability_id的属性。

    • 子model里ability属性实质是父model AblityStandard的对象
    • 子model 里ability_id属性是int和父model主键ability_id保持一致。
    • 子表ability_score里AilityID列是子model的ablity_id属性的值和父model主键ability_id保持一致。
    • ability(外键&父model对象)衍生出ability_id(属性&int) 和AilityID(列名)
    • ability_id虽然在子类AbilityScore里明面代码上没有,实际上是存在的,所以在设唯一约束models.UniqueConstraint(fields=['employee_id', 'ability_id'] name='unique_employee_id_ability_id')时可以直接使用而不报错,具体见下图debug信息。
  • models.ForeignKey()函数的to指定app.model_name (ability_standard.AbilityStandard)

  • 引用时不需要import ability_standard ,Django 自动找。

  • 指定了model_name后通过子表外键(ability = models.ForeignKey)关联了父表的主键(ability_id = models.BigAutoField(db_column='AbilityID', primary_key=True))。这时子表的外键(ablitity)实际上时是父表的model的一个对象,因此可以如下直接通过子表外键获取父表属性:其中ability是子表外键,department是父表的属性。

    python 复制代码
    employee_score.ability.department
  • 建立外键时默认为子表添加了一个属性名_id的字段,可单独指定列名db_column,需要给defualt值。

相关推荐
MATLAB代码顾问3 小时前
5大智能算法优化标准测试函数对比(Python实现)
开发语言·python
ting94520003 小时前
Tornado 全栈技术深度指南:从原理到实战
人工智能·python·架构·tornado
果汁华4 小时前
Browserbase Skills:让 Claude Agent 真正“看见“网页世界
人工智能·python
ZhengEnCi4 小时前
04-缩放点积注意力代码实现 💻
人工智能·python
DeepReinforce4 小时前
三、AI量化投资:使用akshare获取A股主板20260430所有的涨停股票
python·量化·akshare·龙头战法
段一凡-华北理工大学5 小时前
【高炉炼铁领域炉温监测、预警、调控智能体设计与应用】~系列文章08:多模态数据融合:让数据更聪明
人工智能·python·高炉炼铁·ai赋能·工业智能体·高炉炉温
万粉变现经纪人5 小时前
如何解决 pip install llama-cpp-python 报错 未安装 CMake/Ninja 或 CPU 不支持 AVX 问题
开发语言·python·开源·aigc·pip·ai写作·llama
小码哥_常5 小时前
Spring Boot:别再重复造轮子,这些内置功能香麻了
后端
其实防守也摸鱼5 小时前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学
皮皮林5515 小时前
OpenFeign 首次调用卡 3 秒?八年老开发扒透 5 个坑,实战优化到 100ms!
后端