前言
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()
主要特色功能如下:1.注册与否均可购物(同类程序中大多要求注册才能购物),方便了那些懒得注册的客户。降低门槛,自然能抓住更多潜在商机。2.除了同类程序中常见的左侧分类树外,还有顶端分类。左侧分类和顶端分类均可在后台方便的进行管理,左侧分类可任意排序。3.首页通过“新品速递”和“热销商品”两个栏目来展示商品,可自行设置在
0
不坑的代码
立即学习“Python免费学习笔记(深入)”;
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()更多python中SQLAlchemy排序的坑相关文章请关注PHP中文网!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号