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

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

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

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1738閲覧

【Django / Python】 queryset から 外部キーが設定されているカラムの値を取り出したい

azuapricot

総合スコア2341

Django

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/10/25 07:28

いつもお世話になっております。

早速本題に入らせていただきます。

現在、DjangoとPythonを使用してWebアプリケーションの開発を行っているのですが、外部キー が設定されている項目が取得できずに四苦八苦しております。

以下が現在のコードとなります。


views.py

Python

1# MainMaster から 【main_id : 100】を取得 2queryset1 = MainMaster.objects.filter(main_id=100) 3for obj1 in queryset1 : 4 print(obj1 .test_id) # 出力結果:TestMaster object (200) 5 6 # SubMaster から 【test_id : 200】を取得 7 queryset2= SubMaster.objects.filter(test_id=obj1.test_id) 8 9 print(queryset2) # 出力結果:<QuerySet []>

SubMaster の model.py

Python

1class SubMaster(models.Model): 2 class Meta: 3 db_table = 'sub_master' 4 5 sub_id = models.CharField(max_length=260, primary_key=True) 6 test_id = models.ForeignKey(TestMaster, db_column='test_id', on_delete=models.CASCADE)

test_id ではなく、sub_id であれば obj.sub_id で問題なく取得でき、検索結果も返ってくるのですが、

obj.test_id では TestMaster object (200) というオブジェクト?が取得され、検索時の値として使用できません。

どうにか 外部キーが設定されている項目の値を取得 してくる方法はあるのでしょうか。

お時間ある方で、取得方法等、ご存知の方いらっしゃいましたらご助力頂けますと幸いです。

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

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

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

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

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

guest

回答1

0

自己解決

querysetから取り出す方法はわからなかったけれど値だけ取り出す方法は分かった

参考先

Python

1queryset1 = MainMaster.objects.filter(main_id=100) 2 3# ↓ に変更 (.values() を追加) 4 5queryset1 = MainMaster.objects.filter(main_id=100).values()

Python

1for obj1 in queryset1 : 2 print(obj1 .test_id) # 出力結果:TestMaster object (200) 3 4# ↓ に変更 5 6for obj1 in queryset1 : 7 print(obj1['test_id_id']) # 出力結果:200

※ obj1 からの値の取得時

model.py で db_column='test_id' としているにも関わらず、

obj1 から値を取得するときは test_id_id としないと取得できなかった。

投稿2019/10/25 08:08

azuapricot

総合スコア2341

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問