浅析python中SQLAlchemy排序的一个坑

发布时间 - 2026-01-10 23:15:38    点击率:

前言

SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行SQL并获取执行结果。最近在使用SQLAlchemy排序遇到了一个坑,所以想着总结下来,分享给更多的朋友,下面来一起看看吧。

坑的代码

query = db_session.query(UserVideo.vid,
         UserVideo.uid,
         UserVideo.v_width,
         UserVideo.v_height,
         UserVideo.create_time,
         UserVideo.cover,
         UserVideo.source_url,
         UserVideo.v_type,
         UserVideo.category,
         User.username,
         User.sex,
         UserExtraInfo.avatar,
         UserExtraInfo.watermark)
  query = query.filter(UserVideo.status == 1,
        User.uid == UserVideo.uid,
        UserExtraInfo.uid == UserVideo.uid) 
  query = query.filter(UserVideo.status == 1)
  query = query.order_by(-UserVideo.vid)
  query = query.limit(20).all()

不坑的代码

query = db_session.query(UserVideo.vid,
         UserVideo.uid,
         UserVideo.v_width,
         UserVideo.v_height,
         UserVideo.create_time,
         UserVideo.cover,
         UserVideo.source_url,
         UserVideo.v_type,
         UserVideo.category,
         User.username,
         User.sex,
         UserExtraInfo.avatar,
         UserExtraInfo.watermark)
  query = query.filter(UserVideo.status == 1,
        User.uid == UserVideo.uid,
        UserExtraInfo.uid == UserVideo.uid) # .order_by(UserVideo.vid.desc()).limit(20).all()
  query = query.filter(UserVideo.status == 1)
  query = query.order_by(UserVideo.vid.desc())
  query = query.limit(20).all()

对,你没看错,就是那个横杠,拉慢速度。改成 desc() 函数速度能提高10倍

下面附上一个 sqlalchemy 高性能随机取出若干条数据

query = db_session.query(UserVideo.vid,
          UserVideo.uid,
          UserVideo.v_width,
          UserVideo.v_height,
          UserVideo.create_time,
          UserVideo.cover,
          UserVideo.source_url,
          UserVideo.v_type,
          UserVideo.category,
          User.username,
          User.sex,
          UserExtraInfo.avatar,
          UserExtraInfo.watermark)
   query = query.filter(UserVideo.status == 1, User.uid == UserVideo.uid, UserExtraInfo.uid == UserVideo.uid)
rvid = db_session.query(func.round(random.random() * func.max(UserVideo.vid)).label('rvid')).subquery()
query = query.filter(UserVideo.category == category)
query_tail = query
query_tail = query_tail.join(rvid, UserVideo.vid > rvid.c.rvid).limit(20).all()

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# sqlalchemy  # 排序  # python  # python使用sqlalchemy  # Python SQLAlchemy入门教程(基本用法)  # Python的SQLAlchemy框架使用入门  # sqlalchemy实现时间列自动更新教程  # 你没  # 这篇文章  # 谢谢大家  # 高性能  # 看看吧  # 转换成  # 看错  # 编程语言  # 有疑问  # vid  # uid  # db_session  # UserVideo  # v_width  # source_url  # v_type  # category  # v_height  # create_time  # cover 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现一对一模型关联?(Eloquent示例)  高端建站三要素:定制模板、企业官网与响应式设计优化  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  Laravel如何处理CORS跨域请求?(配置示例)  Laravel如何生成URL和重定向?(路由助手函数)  IOS倒计时设置UIButton标题title的抖动问题  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  Thinkphp 中 distinct 的用法解析  Laravel如何集成Inertia.js与Vue/React?(安装配置)  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  Laravel如何配置任务调度?(Cron Job示例)  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  js代码实现下拉菜单【推荐】  如何在IIS中新建站点并解决端口绑定冲突?  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  如何在IIS7中新建站点?详细步骤解析  怎么用AI帮你为初创公司进行市场定位分析?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  晋江文学城电脑版官网 晋江文学城网页版直接进入  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  Laravel如何使用Blade组件和插槽?(Component代码示例)  Laravel中的Facade(门面)到底是什么原理  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  lovemo网页版地址 lovemo官网手机登录  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  如何快速辨别茅台真假?关键步骤解析  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  如何在阿里云域名上完成建站全流程?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  如何在IIS中配置站点IP、端口及主机头?  Laravel如何使用Livewire构建动态组件?(入门代码)  深圳网站制作的公司有哪些,dido官方网站?  英语简历制作免费网站推荐,如何将简历翻译成英文?  js实现点击每个li节点,都弹出其文本值及修改  如何快速启动建站代理加盟业务?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  Laravel如何为API编写文档_Laravel API文档生成与维护方法  Python制作简易注册登录系统  Bootstrap整体框架之JavaScript插件架构  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】  青岛网站建设如何选择本地服务器?