簡體   English   中英

Django MySql,外鍵查詢

[英]Django MySql, foreign key query

我在Django中有以下模型。

from django.db import models

#Show DB Table Model

class Shows(models.Model):
    show_key = models.CharField(primary_key=True, max_length=7)
    show_date = models.DateField(blank=True, null=True)
    show_venue = models.CharField(max_length=50, blank=True, null=True)
    show_city = models.CharField(max_length=50, blank=True, null=True)
    show_state = models.CharField(max_length=3, blank=True, null=True)
    show_country = models.CharField(max_length=3, blank=True, null=True)

class Meta:
    managed = False
    db_table = 'shows'

#Songs DB Table Model

class Songs(models.Model):
    song_key = models.CharField(primary_key=True, max_length=8)
    show_key = models.ForeignKey('Shows', models.DO_NOTHING, db_column='show_key', blank=True, null=True)
    song_name = models.CharField(max_length=100, blank=True, null=True)
    song_set = models.CharField(max_length=20, blank=True, null=True)
    song_track = models.IntegerField(blank=True, null=True)
    song_encore = models.IntegerField(blank=True, null=True)
    song_segue = models.CharField(max_length=1, blank=True, null=True)
    song_notes = models.CharField(max_length=100, blank=True, null=True)
    song_cover = models.CharField(max_length=50, blank=True, null=True)
    song_with_guest = models.CharField(max_length=50, blank=True, null=True)



class Meta:
    managed = False
    db_table = 'songs'

我正在嘗試進行查詢,以找到滿足特定條件的所有對象,即:

Shows.objects.filter(show_date__year=2000)

以上查詢將返回多個對象。

我需要更進一步,並從Songs表/模型中提取與已過濾的Show對象有關的所有信息。 在“ show_key”是主鍵/外鍵關系並且是一對多的意義上,模型是相關的。

我還需要將所有找到的數據打包成一個可用的形式,以進行迭代並發送到jinja2模板。

例如:

{% for item in query_results %}
<ul>
    <li>item.show_date</li>
    <li>item.show_venue</li>
    <li>item.show_city</li>
    <li>item.show_state</li>
    <li>item.show_country</li>
</ul>
    <ul>
    {% for song in item %}
        <li>song.song_name</li>
        <li>song.song_set</li>
        <li>song.song_track</li>
        <li>song.song_encore</li>
        <li>song.song_segue</li>
        <li>song.song_notes</li>
    </ul>
    {% endfor %}

提前致謝。 布倫特

好像您要嘗試的是向后遵循FK關系

這是模板中的樣子:

{% for show in query_results %}
<ul>
    <li>show.show_date</li>
    <li>show.show_venue</li>
    <li>show.show_city</li>
    <li>show.show_state</li>
    <li>show.show_country</li>
</ul>
    <ul>
    {% for song in show.entry_set.all %}
        <li>song.song_name</li>
        <li>song.song_set</li>
        <li>song.song_track</li>
        <li>song.song_encore</li>
        <li>song.song_segue</li>
        <li>song.song_notes</li>
    </ul>
   {% endfor %}

實際上,這將迫使jango為每個節目發出一個SQL查詢。 如果您太多,可能會很痛苦。 為了避免這種情況,您可以告訴Django在查詢節目時選擇相關的歌曲數據。 這樣可以節省大量SQL查詢。

Shows.objects.select_related(Songs).filter(show_date__year=2000)

我終於想通了!

首先,我查詢了Shows模型/表並將結果保存到query_results:

query_results = Shows.objects.filter(show_date__year=2018)

然后在我的Jinja模板中

{% for show in query_results %}
<ul>
    <li>{{show.show_date}}</li>
    <li>{{show.show_venue}}</li>
    <li>{{show.show_city}}</li>
    <li>{{show.show_state}}</li>
    <li>{{show.show_country}}</li>
</ul>
    <ul>
    {% for song in show.songs_set.all %}  #This is the key, calling the related "shows_set.all" This grabs the related objects from the Songs table/model
        <li>{{song.song_name}}</li>
        <li>{{song.song_set}}</li>
        <li>{{song.song_track}}</li>
        <li>{{song.song_encore}}</li>
        <li>{{song.song_segue}}</li>
        <li>{{song.song_notes}}</li>
    {% endfor %}
    </ul>
{% endfor %}

暫無
暫無

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

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