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

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

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

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

SQLAlchemy

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

Q&A

0回答

2225閲覧

SQLAlchemy のexecute() 結果を、dtoで受け取る方法ってありますか?

tfline_w

総合スコア37

Python 3.x

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

SQLAlchemy

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

0グッド

1クリップ

投稿2018/08/10 10:51

SQLAlchemy で、session.execute() の結果を、dto で受け取る方法があれば、知りたいです。

現在、SQLAlchemy をいろいろ試しています。単純に1つのテーブルから値を取得する方法は、だいたいわかったのですが、

・複数テーブルをJOIN した結果を取得したい
・ただし、SQL はORM に任せず自分で記述したい
・ただし、結果はRowProxy ではなく、dto(Class) のリストとして取得したい

というようなことができるのでしょうか。

データベースには、userMaster と、sectionMaster の2つのテーブルがあるとして、

class UserInfo(): userID = Column('userID', Integer) userName = Column('userName', String) sectionID = Column('sectionID', Integer) sectionName = Column('sectionName', String)

こんなClass を定義しておき、

sql = "select um.userID, um.userName, um.sectionID, sm.sectionName from userMaster as um INNER JOIN sectionMaster as sm on um.sectionID = sm.sectionID limit 10" userList = session.execute(sql)

と実行したとき、userList が、UserInfo のリストになっているような想定です。
試しに、

userList = session.query(UserInfo).from_statement(sql)

とやってみたのですが、

sqlalchemy.exc.InvalidRequestError: SQL expression, column, or mapped entity expected

とエラーになってしまいました。

普通にRowProxy で取得した後、dto に変換するのでも構わないのですが、

userList = session.execute(sql) for userInfo in userList: #ここで変換したい

どのように変換したらいいのかわかりません。

何かうまい方法があれば教えていただけると助かります。
もしくは、それはできない、という回答でも助かります。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問