python - 使用sqlalchemy操作mysql,如何获取随机几项?
高洛峰
高洛峰 2017-04-17 17:38:33
0
1
431
users_query = db_session.query(User).filter(
    ~User.id.in_(followed_user_ids),
    User.status.in_([User.STATUS_NORMAL, User.STATUS_SUPER])
)

用.all()的话,结果太多了,我只想随机要5项,怎么写呢?

查了下stackoverflow已经解决:
http://stackoverflow.com/search?q=sqlalchemy+random

users = users_query.order_by(func.rand()).limit(5)
高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

répondre à tous(1)
阿神

5 éléments aléatoires, ou les 5 premiers éléments ?

S'il s'agit des cinq premiers éléments, c'est relativement simple :

users_query = db_session.query(User).filter(
    ~User.id.in_(followed_user_ids),
    User.status.in_([User.STATUS_NORMAL, User.STATUS_SUPER])
).limit(5).all()

S'il s'agit de 5 éléments aléatoires, ajoutez quelque chose :

from  sqlalchemy.sql.expression import func

users_query = db_session.query(User).filter(
    ~User.id.in_(followed_user_ids),
    User.status.in_([User.STATUS_NORMAL, User.STATUS_SUPER])
).order_by(func.random()).limit(5).all()
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal