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

 刺客狙侠者 发布于 2022-11-02 19:31
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)
1 个回答
  • 是随机 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()
    2022-11-04 18:16 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有