SQLAlchemy 中的Group By用法

這里我們要用到的query對(duì)象的方法:

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

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

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

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

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

SQL語(yǔ)句的用法如下:

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中針對(duì)Group By還可以再進(jìn)一步篩選,但是要用另一個(gè)關(guān)鍵詞Having

SQL語(yǔ)句的用法如下:

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)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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