1

ORMにElixirを使用していますが、関係で注文しようとすると問題が発生します。

私がやろうとしているのは、投稿数でソートされたユーザーのリストを取得することです。私は次のような方法を試しました

User.query.join(User.posts).order_by(func.count(User.posts)).all()

成功せずに。

これが私のElixirエンティティです:

class User(Entity):
    username = Field(Unicode(100))
    posts = OneToMany('Post', inverse='user')


class Post(Entity):
    content = Field(Unicode(20000))
    user = ManyToOne('User')
4

1 に答える 1

5

これはよくある質問で、クエリの例はhttp://www.sqlalchemy.org/docs/orm/tutorial.html#using-subqueriesの ORM チュートリアルにあります。order_by(User.id) と表示されている箇所を order_by(stmt.c.address_count) に変更するだけです。

>>> from sqlalchemy.sql import func
>>> stmt = session.query(Address.user_id, func.count('*').\
...         label('address_count')).\
...         group_by(Address.user_id).subquery()

>>> for u, count in session.query(User, stmt.c.address_count).\
...     outerjoin(stmt, User.id==stmt.c.user_id).order_by(stmt.c.address_count): 
...     print u, count
于 2011-10-31T17:07:41.720 に答える