淺析python中SQLAlchemy排序的一個(gè)坑
前言
SQLAlchemy是Python編程語(yǔ)言下的一款ORM框架,該框架建立在數(shù)據(jù)庫(kù)API之上,使用關(guān)系對(duì)象映射進(jìn)行數(shù)據(jù)庫(kù)操作,簡(jiǎn)言之便是:將對(duì)象轉(zhuǎn)換成SQL,然后使用數(shù)據(jù)API執(zhí)行SQL并獲取執(zhí)行結(jié)果。最近在使用SQLAlchemy排序遇到了一個(gè)坑,所以想著總結(jié)下來(lái),分享給更多的朋友,下面來(lái)一起看看吧。
坑的代碼
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()
對(duì),你沒看錯(cuò),就是那個(gè)橫杠,拉慢速度。改成 desc() 函數(shù)速度能提高10倍
下面附上一個(gè) sqlalchemy 高性能隨機(jī)取出若干條數(shù)據(jù)
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()
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Python樹莓派學(xué)習(xí)筆記之UDP傳輸視頻幀操作詳解
這篇文章主要介紹了Python樹莓派學(xué)習(xí)筆記之UDP傳輸視頻幀操作,結(jié)合實(shí)例形式詳細(xì)分析了Python樹莓派編程中使用UDP協(xié)議進(jìn)行視頻幀傳輸?shù)南嚓P(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-11-11
Tensorflow之構(gòu)建自己的圖片數(shù)據(jù)集TFrecords的方法
本篇文章主要介紹了Tensorflow之構(gòu)建自己的圖片數(shù)據(jù)集TFrecords的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-02-02
Python實(shí)現(xiàn)統(tǒng)計(jì)英文文章詞頻的方法分析
這篇文章主要介紹了Python實(shí)現(xiàn)統(tǒng)計(jì)英文文章詞頻的方法,結(jié)合實(shí)例形式分析了Python針對(duì)英文單詞頻率統(tǒng)計(jì)的相關(guān)原理、實(shí)現(xiàn)方法及具體操作技巧,需要的朋友可以參考下2019-01-01
利用Python快速搭建Markdown筆記發(fā)布系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了使用Python生態(tài)的成熟工具,在30分鐘內(nèi)搭建一個(gè)支持Markdown渲染、分類標(biāo)簽、全文搜索的私有化知識(shí)發(fā)布系統(tǒng),感興趣的小伙伴可以參考下2025-04-04

