使用sqlalchemy操作mysql,如何获取随机几项?

发布于 2022-09-02 14:10:32 字数 448 浏览 12 评论 0

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)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

猫九 2022-09-09 14:10:32

是随机 5 项,还是前 5 项?

如果是前五项,比较简单:

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()

如果是随机5项,要加一些东西:

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()
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文