2009-06-01 60 views
2

我有2种型号,看起来像:获取/呈现一对多关系的最佳方式是什么?

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 %} 

任何人都可以告诉我,如果我考虑这样做的正确方法,然后如何在模板中访问这些数据?

谢谢!

回答

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 %} 
+0

它现在伟大的工作。谢谢! – 2009-06-01 05:27:57

相关问题