質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Q&A

0回答

205閲覧

関連するQueryが深くなる

Kentaro0919

総合スコア258

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

0グッド

0クリップ

投稿2017/12/07 01:58

span-relationshipsによると

python

1Entry.objects.filter(blog__name='Beatles Blog')

のように関連する項目を取ることができます

python

1class Year(models.Model): 2 year = models.PositiveIntegerField( 3 validators=[ 4 MinValueValidator(1900), 5 MaxValueValidator(datetime.now().year)], 6 help_text="Use the following format: <YYYY>", 7 unique=True) 8 created = CreationDateTimeField() 9 modified = ModificationDateTimeField() 10 11 def __str__(self): 12 return f"{self.year}" 13 14 15class Month(models.Model): 16 year = models.ForeignKey(Year, on_delete=models.CASCADE, 17 blank=True, null=True, db_index=True) 18 month = models.PositiveIntegerField( 19 validators=[ 20 MinValueValidator(1), 21 MaxValueValidator(12)], 22 help_text="Use the following format: <MM>") 23 created = CreationDateTimeField() 24 modified = ModificationDateTimeField() 25 26 def __str__(self): 27 return f"{self.year} {self.month}" 28 29 class Meta: 30 unique_together = (("year", "month"),)

実際に次のコードで取得が可能です。

python

1Month.objects.get(month=1, year__year=2017)

ただこうするとどんどんリンク先が深くなるので、例えばこのテーブルに「day」を追加したら

python

1Day.objects.get(day=1, month__month=1, month__year__year=2017)

とどんどん深くなっていってしまいます、テーブルの設計が悪いのかもしれませんが、ショートカットするいい方法はないでしょうか

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問