SQL Having用法

拿个业务场景说这个案例,比如我们有个表里面可能有批改过的数据,批改过得数据不会随着新批改的数据覆盖,而是逐条插入表中,如果想找出包含最早批改的数据和最新批改数据的话,那么我们就需要用到了havinng 用法,假设最开始的批单号是000,批单号是累加的

比如我们有个表 table 表里面有两个字段 订单号(order_no) 和 批单号(endorseq_no)

那么写法就是

sql 复制代码
select order_no
from table
group by order_no
having sum(case when endorseq_no = '000' then 1 
                else 0 end) >= 1  --这个是判断必须包含最初的批单
  and count(*) >= 2    --这个是判断除了最初的批单之外还需要有新批改的批单
相关推荐
IvorySQL5 分钟前
PostgreSQL 18 - 时间约束 (Temporal Constraints)
数据库·postgresql·开源
q***614115 分钟前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
N***738535 分钟前
SQL锁机制
java·数据库·sql
小羊在奋斗44 分钟前
MySQL表的约束:从基础到核心(附场景+案例)
android·数据库·mysql
Wang's Blog1 小时前
MongoDB小课堂: 文档查询之匹配查询与比较操作符深度解析
数据库·mongodb
cookqq1 小时前
mongodb根据索引IXSCAN 查询记录流程
数据结构·数据库·sql·mongodb·nosql
p***32351 小时前
如何使用C#与SQL Server数据库进行交互
数据库·c#·交互
6***v4171 小时前
spring boot 项目打印sql日志和结果,使用logback或配置文件
spring boot·sql·logback
h***34632 小时前
Redis安装教程(Windows版本)
数据库·windows·redis
泡沫·3 小时前
5.MariaDB数据库管理
数据库·mariadb