我有两个模型Project
和Group
。我的团队属于特定项目。我的群组包含字段project = ForeignKey(Project)
和parent = ForeignKey('self')
。
我可以使用limit_choices_to
来确保外键parent
中的选项只包含同一项目中的组吗?
我在考虑像
这样的东西def limit_choices_to(self):
return {'project': self.project}
答案 0 :(得分:4)
这在模型级别是不可能的,但您可以在表单的构造函数中更改此字段的查询集。
class GroupForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
super(GroupForm, self).__init__(*args, **kwargs)
if self.instance.project:
self.fields['parent'].queryset = Group.objects.filter(
project=self.instance.project)
更新:要在管理员中执行此操作,您必须设置ModelAdmin
的{{3}}属性:
class GroupAdmin(admin.ModelAdmin):
form = GroupForm