获取/呈现一对多关系的最佳方法是什么?

时间:2009-06-01 05:01:39

标签: python django

我有两个看起来像这样的模型:

class Entry(models.Model):
user = models.ForeignKey(User)
dataname = models.TextField()
datadesc = models.TextField()
timestamp = models.DateTimeField(auto_now=True)

class EntryFile(models.Model):
    entry = models.ForeignKey(Entry)
    datafile = models.FileField(upload_to="uploads/%Y/%m/%d/%H-%M-%S")

我想为特定用户呈现所有条目及其相关文件。 现在我在我的视图中这样做以获取值:

    entries = Entry.objects.filter(user=request.user).order_by("-timestamp")
    files = {}
    for entry in entries:
        entryfiles = EntryFile.objects.filter(entry=entry)
        files[entry] = entryfiles
    return render_to_response("index.html", {'user': request.user, 'entries': entries, 'files': files, 'message': message})

但我无法/不知道如何在我的模板中使用这些数据。这就是我现在所做的,但不起作用:

{% for entry in entries %}
    <td>{{ entry.datadesc }}</td>
    <td><table>
        {{ files.entry }}
        {% for file in files.entry %}
        <td>{{ file.datafile.name|split:"/"|last }}</td>
        <td>{{ file.datafile.size|filesizeformat }}</td>
        <td><a href="{{ object.datafile.url }}">download</a></td>
        <td><a href="{% url main.views.delete object.id %}">delete</a></td>
        {% endfor %}
    </table></td>
{% endfor %}

任何人都可以告诉我,我是否以正确的方式在视图中进行操作,然后如何在模板中访问这些数据?

谢谢!

1 个答案:

答案 0 :(得分:5)

只需将您的观看代码剪切到此行:

entries = Entry.objects.filter(user=request.user).order_by("-timestamp")

在模板中执行此操作:

{% for entry in entries %}
    <td>{{ entry.datadesc }}</td>
    <td><table>
    {% for file in entry.entryfile_set.all %}
        <td>{{ file.datafile.name|split:"/"|last }}</td>
        <td>{{ file.datafile.size|filesizeformat }}</td>
        <td><a href="{{ object.datafile.url }}">download</a></td>
        <td><a href="{% url main.views.delete object.id %}">delete</a></td>
    {% endfor %}
    </table></td>
{% endfor %}

我非常喜欢在模型中使用related_name,所以你可以改变这一行:

entry = models.ForeignKey(Entry)

对此:

entry = models.ForeignKey(Entry, related_name='files')

然后您可以通过更改以下内容来访问特定条目的所有文件:

{% for file in files.entryfile_set.all %}

更具可读性/显而易见性:

{% for file in entry.files.all %}