SQLAlchemy 中的Group By用法

這里我們要用到的query對象的方法:

  • .filter_by(..)
  • .group_by(..)
  • .having(..)

我們需要額外導(dǎo)入的方法:
from sqlalchemy import func

func方法主要用來做統(tǒng)計,映射到sql語句中具體的統(tǒng)計方法,如:

  • func.count(..)
  • func.sum(..)

func方法的格式為:func('字段名').label('顯示名')

SQL語句的用法如下:

SELECT school, COUNT(*) AS c FROM persons WHERE gender="male" GROUP BY age

SQLAlchemy中如下:

from sqlalchemy import func

results = sessin.query( Person.school, func.count('*').label('c') ).filter(
    Person.gender=='male'
).group_by( Person.age )

篩選

SQL中針對Group By還可以再進一步篩選,但是要用另一個關(guān)鍵詞Having。

SQL語句的用法如下:

SELECT school, COUNT(*) AS c FROM persons WHERE gender="male" GROUP BY age HAVING c >1

SQLAlchemy中如下:

nums = func.count('*').label('c')

results = sessin.query( Person.school, nums ).filter(
    Person.gender=='male'
).group_by(
    Person.age
).having(
    nums > 10
)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容