淺析python中SQLAlchemy排序的一個坑,pythonsqlalchemy

來源:互聯網
上載者:User

淺析python中SQLAlchemy排序的一個坑,pythonsqlalchemy

前言

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 = queryquery_tail = query_tail.join(rvid, UserVideo.vid > rvid.c.rvid).limit(20).all()

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的協助,如果有疑問大家可以留言交流,謝謝大家對幫客之家的支援。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.