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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

SQLAlchemy

SQLAlchemyとはPython 用のORMライブラリです。MIT Licenceのオープンソースとして提供されています。

Python

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

Q&A

解決済

2回答

2388閲覧

sqlAlchemyでのmany to manyテーブルからのデータの取得

pen_ari

総合スコア50

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

SQLAlchemy

SQLAlchemyとはPython 用のORMライブラリです。MIT Licenceのオープンソースとして提供されています。

Python

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

0グッド

0クリップ

投稿2021/12/08 12:12

編集2021/12/08 12:24

sqlAlchemyでmany to many(多対多)の構造のDBを作成し、紐づくテーブルのデータも含めてデータを取得したいのですがそのやり方がわからず困っています
具体的にはparentとchildテーブルがあり、親は複数人子がおり、子も複数人親がいる状態のとき、
親の情報を取得したときに子の配列を取得したいです
ソースは以下です

model.py

python

1association_table = Table('association', Base.metadata, 2 Column('parent_id', ForeignKey('parent.id'), primary_key=True), 3 Column('child_id', ForeignKey('child.id'), primary_key=True) 4) 5 6class Parent(Base): 7 __tablename__ = 'parent' 8 id = Column(Integer, primary_key=True) 9 children = relationship( 10 "Child", 11 secondary=association_table, 12 back_populates="parents") 13 14class Child(Base): 15 __tablename__ = 'child' 16 id = Column(Integer, primary_key=True) 17 parents = relationship( 18 "Parent", 19 secondary=association_table, 20 back_populates="children")

query.py

Python

1from sqlalchemy.orm import Session 2from model import * 3 4def retreive_parent(id: int, db: Session): 5 parent = db.query(Parent).filter(Parent.id == id).first() 6 return parent

期待する出力

{ "id": 1, "children": [{"id": 1},{"id": 2},{"id": 3}] }

実際の出力

{ "id":1 }

なんとなくquery時にjoinをするのかなと思ってchildテーブルやassosiation_tableをjoinしてみましたが上手くいきません

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

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

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

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

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

guest

回答2

0

ベストアンサー

relationship全般の性質かなと思います。このページですね。

https://docs.sqlalchemy.org/en/14/orm/loading_relationships.html

When the given collection or reference is first accessed on a particular object, an additional SELECT statement is emitted such that the requested collection is loaded.

(DeepL)特定のオブジェクトで指定されたコレクションや参照に最初にアクセスしたとき、要求されたコレクションが読み込まれるように、追加のSELECT文が発行されます。

ここで6種類ほど、戦略が挙げられています。


デフォルトパラメータは
https://docs.sqlalchemy.org/en/14/orm/relationship_api.html#sqlalchemy.orm.relationship

lazy='select',

なので、上で挙げたページだと

this is the form of loading that emits a SELECT statement at attribute access time to lazily load a related reference on a single object at a time.

(DeepL)これは、アトリビュートアクセス時にSELECT文を発行して、一度に一つのオブジェクトの関連参照をレイジーにロードするローディングの形式です。

と説明されてます。

投稿2021/12/09 00:48

quickquip

総合スコア11038

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

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

pen_ari

2021/12/09 01:04

model作成時に指定できたんですね ありがとうございます
guest

0

よくわからないんですが、
returnする前に

python

1print(parent.children)

としてからreturnしたところ期待するオブジェクトがreturnされました
もうすこし調査してみます

投稿2021/12/08 13:07

pen_ari

総合スコア50

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

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

pen_ari

2021/12/09 01:14

追記です 当方fastAPIを利用しているのですが、response_modelでschemaを指定することによって validation時に自動でlazyloadさせることも可能なようです
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問