在django项目的开发过程中,在设计模型时一开始将主键设置成了一个自定义的字段,但是在创建搜索索引时却发现必须要存在一个id的字段,并且为主键(不知道是否是项目一开始就这样配置的原因), 但此时表结构已经整体固定下来,并且有外键关联到了这个自定义的的主键,整个后台视图逻辑也已经封装完成,如果主表的主键发生改变,那么外键所在的表就会默认关联到新的主键上,那个后台视图的改动就会非常麻烦,这时就需要使用外键字段中的to_field属性来指定所关联的主表的某个字段,而不会影响到原先的逻辑
demo如下:
from uuid import uuid4from django.db import models
class CourseInfo(models.Model): # 使用Bigint id = models.BigAutoField(primary_key=True) # 使用to_field关联到了这个字段,所以必须设置unique=True course_id = models.UUIDField(auto_created=True, default=uuid4, editable=False, unique=True, db_index=True) class Learner(models.Model): id = models.AutoField(primary_key=True) course = models.ForeignKey(CourseInfo, to_field="course_id")
原文地址:https://www.cnblogs.com/lowmanisbusy/p/9217592.html
时间: 2024-10-23 22:30:27