pgsql 分组查询方法

  • group by

    group by 查询的字段 必须出现在分组中。因此这里用 max 函数,来查其他字段

sql 复制代码
SELECT
	 "max"("name") as "name",
	 "max"("organization_id") as "organizationId",
	 account
FROM
	system_users 
GROUP BY account
  • PARTITION BY

Partition By是分组但不聚合

是按 account 进行分组且组内按 create_time 进行升序,返回组内行编号

rownum = 1 可以实现去重的效果

sql 复制代码
WITH res AS (
SELECT
	 organization_id,
	 "name",
	 account,
	 ROW_NUMBER() OVER(PARTITION BY "account" ORDER BY "create_time" ASC nulls last) AS rownum
FROM
	system_users 
)
SELECT * FROM res WHERE rownum = 1
相关推荐
廋到被风吹走13 小时前
【Spring】事务管理深度解析|从原理到实战
java·spring
思成不止于此13 小时前
【MySQL 零基础入门】DDL 核心语法全解析:数据库与表结构操作篇
数据库·笔记·学习·mysql
lkbhua莱克瓦2413 小时前
Java进阶——IO流
java·开发语言·笔记·学习方法·io流
韩立学长13 小时前
【开题答辩实录分享】以《自选便利店商品分类管理系统》为例进行选题答辩实录分享
java·mysql·web
aspirestro三水哥13 小时前
2.5构建Xenomai测试与演示镜像
数据库·rtos·xenomai
阿杰同学13 小时前
Java中55种锁,高级面试题,最新面试题
java·开发语言
随机昵称_12345613 小时前
postgresql连接报错Invalid SCRAM client initialization
数据库·postgresql
清晓粼溪13 小时前
SpringCloud01-基础概念
java·开发语言·spring cloud
路边草随风13 小时前
java实现发布flink yarn application模式作业
java·大数据·flink·yarn
gaize121313 小时前
服务器异常如何解决
运维·服务器