您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

在PostgreSQL中按月和年对查询结果进行分组

在PostgreSQL中按月和年对查询结果进行分组

select to_char(date,'Mon') as mon,
       extract(year from date) as yyyy,
       sum("Sales") as "Sales"
from yourtable
group by 1,2

应Radu的要求,我将解释该查询

to_char(date,'Mon') as mon, :将“日期”属性转换为月的简短形式的定义格式。

extract(year from date) as yyyy :Postgresql的“提取功能用于从“日期”属性提取YYYY年。

sum("Sales") as "Sales" :SUM()函数将所有“ Sales”值相加,并提供区分大小写的别名,并使用双引号保持区分大小写。

group by 1,2注意:GROUP BY函数必须包含SELECT列表中不属于聚合的所有列(也就是,所有列不在SUM / AVG / MIN / MAX等函数之内)。这告诉查询应将SUM()应用于每个唯一的列组合,在这种情况下为月和年列。尽管可能最好使用完整的“ to_char(…)”和“ extract(…)”表达式以提高可读性,但“ 1,2”部分是简化的方式,而不是使用列别名。

SQLServer 2022/1/1 18:53:17 有458人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶