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

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

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

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

Python

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

Q&A

1回答

1322閲覧

Django 中間テーブルのソートにつきまして

rmnmao

総合スコア0

Django

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

Python

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

0グッド

0クリップ

投稿2021/05/14 04:17

前提・実現したいこと

Djangoの中間テーブルを追加した順番(ID順)でソートしたいです。
Productテーブルに対し、タグを追加していますが、
追加したタグの順番で抽出を行う方法はございますでしょうか?

該当のソースコード

models

class Tag(models.Model): tid = models.BigIntegerField("タグID", primary_key=True) name = models.CharField("名前", max_length=18, default='', blank=True) class Meta: db_table = 'Tag' class Product(models.Model): pid = models.BigIntegerField("プロダクトID", primary_key=True) tags = models.ManyToManyField(Tag, verbose_name="タグ", related_name='tags', blank=True) class Meta: db_table = 'Product'

タグとプロダクトオブジェクトの追加
tag2 -> tag1の順番で保存しています。

python3

1tag1 = Tag.objects.create(tid=1, name='test1') 2tag2 = Tag.objects.create(tid=2, name='test2') 3 4product = Product.objects.create(pid=1) 5product.tags.add(tag2) 6product.tags.add(tag1) 7product.save()

中間テーブル

select * from Product_tags; +----+------------+--------+ | id | product_id | tag_id | +----+------------+--------+ | 2 | 1 | 1 | | 1 | 1 | 2 | +----+------------+--------+

追加したプロダクトに設定しているタグ名リストを取得

product = Product.objects.get(pid=1) print(list(product.tags.values_list('name', flat=True))) ['test1', 'test2']

追加した順番で['test2', 'test1']と出力されるのが期待動作です。

試したこと

order_by('tags__pk')でソートを行ってもProduct_tags.product_idがキーとなってしまいます。
※Product_tagsのPrimaryKeyはIDなのになぜ...?
Product_tags.idでソートできる方法はございますでしょうか?

print(list(product.tags.order_by('tags__pk').values_list('name', flat=True))) SELECT `Tag`.`name` FROM `Tag` INNER JOIN `Product_tags` ON (`Tag`.`tid` = `Product_tags`.`tag_id`) WHERE `Product_tags`.`product_id` = 1 ORDER BY `Product_tags`.`product_id` ASC

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

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

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

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

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

guest

回答1

0

こんにちは。

問題文拝見しました。

order_by('tags__pk')でソートを行ってもProduct_tags.product_idがキーとなってしまいます。

.order_by('xxx').reverse()のreverseなどを利用してはいかがでしょうか?

<参考>
https://www.nblog09.com/w/2019/02/03/django-order-by/
https://qiita.com/Hyperion13fleet/items/1a0369f4f5d523be5870
https://docs.djangoproject.com/en/dev/ref/models/querysets/#order-by

投稿2021/05/14 05:54

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

rmnmao

2021/05/14 06:32

ご回答ありがとうございます。 ソート順を逆では汎用的ではなく一時的な対応になってしまいます。 汎用的にidをキーに指定したいのです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問