浅析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批量生成测试数据【方法】
青岛网站建设如何选择本地服务器?

