簡體   English   中英

如何列出具有相同 ForeignKey 屬性的對象?

[英]How to list objects that have the same ForeignKey attribute?

我想在一頁上列出所有具有相同approval_id的批准步驟。 我可以在我的視圖中列出每個ApprovalSteps ,但這不是我想要的。 例如,我有一個審批 object,其中ApprovalProcess id 為 1。我想在我的模板中列出所有審批步驟,其中approval_id = 1。 我怎樣才能做到這一點?

模型.py

class ApprovalProcess(models.Model):
    id = models.AutoField(primary_key=True)
    user_id = models.ForeignKey(UserProfile, on_delete=models.CASCADE, null=True, related_name='starter')
    doc_id = models.ForeignKey(Pdf, on_delete=models.CASCADE, null=True)
    ...


class ApprovalSteps(models.Model):
    approval_id = models.ForeignKey(ApprovalProcess, on_delete=models.CASCADE, null=True)
    starter = models.ForeignKey(UserProfile, on_delete=models.CASCADE, null=True, related_name='step_starter')
    ...

視圖.py

def approval_details(request, pk):
    approval_item = get_object_or_404(ApprovalSteps, id=pk)
    return render(request, 'approval_details.html', {'approval_item': approval_item})

您可以將您的approval_details視圖function 更改為

def approval_details(request, pk):
    approval_items_list = get_list_or_404(ApprovalSteps, approval_id=pk)
    return render(request, 'approval_details.html', {'approval_items_list': approval_items_list})

參考這里

要訪問ApprovalProcessApprovalSteps的相關對象,您可以使用_set ( Django Docs )。

因此,在您的情況下,您的模板approval_item.approval_id_set.all

{% for item in approval_item.approval_id_set.all %}
    {{ item.doc_id }}
{% endfor %}

在views.py中:

approval_item.approval_id_set.all()

或使用ForeignKey.related_name

approval_id = models.ForeignKey(
    ApprovalProcess, on_delete=models.CASCADE, null=True, 
    related_name="processes"
)
# then you can use 
approval_item.processes.all()

另外,我建議您將approval_id重命名為approval ,因為:

在幕后,Django 將“_id”附加到字段名稱以創建其數據庫列名稱,請參閱Django ForeignKey

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM