sql 如何在查询时移除某一行数据以及这一行的上一行数据

oracel 有个rownum 函数, 它可以为 某一行 数据增加一个序列比如查出的序列值便是

json 复制代码
[
{"name": "法外狂徒-张三",option":"申请团长", rownum:1},
{"name": "法外狂徒-张三","option":"申请人撤销", rownum:2},
{"name": "法外狂徒-张三","option":"申请旅长", rownum:3},
{"name": "法外狂徒-张三","option":"司令通过", rownum:4},
{"name": "法外狂徒-张三","option":"申请师长", rownum:5},
{"name": "法外狂徒-张三","option":"申请人撤销", rownum:6},
{"name": "法外狂徒-张三","option":"申请军长", rownum:7},
{"name": "法外狂徒-张三","option":"司令通过", rownum:8},
]

以上是表内的结果集,由于申请人撤销了操作,所以它之前的操作是无效的, 在页面也不显示, 申请人撤销这个字段是固定的,它之前的操作不固定, 所以如果想要过滤掉它之前的数据,我们需要先过去到申请人撤销那条数据的下标,再去-1.

想法, 我们可以先查询上面的结果集, 并且通过rownum为每个结果集定义一个固定的序号, 查询结果集select * from 结果集 where rownum not in ((select rownum from (结果集) where option = "申请人撤销" unine all select rownum -1 from (结果集) where option = "申请人撤销"))

这样我们就得到如下结果

json 复制代码
[

{"name": "法外狂徒-张三","option":"申请旅长", rownum:3},
{"name": "法外狂徒-张三","option":"司令通过", rownum:4},
{"name": "法外狂徒-张三","option":"申请军长", rownum:7},
{"name": "法外狂徒-张三","option":"司令通过", rownum:8},
]

由于结果集被反复使用到,我们在mybatis中可以将结果集sql 提出到sql片段中,便于反复调用

Mybaits.xml

xml 复制代码
<sql id= "dataSource">
  select t*,rownum as id from 表名 where t.name=#{name} order by operTime
</sql>

<sql id="removeRowIndex">
	select id from (<include refid="dataSource"/>) where option="申请人撤销"
	union all 
	select id-1 from (<include refid="dataSource"/>) where option="申请人撤销"
</sql>

<select id="getFolw" resultMap="java.util.HashMap" parameterType="java.util.HashMap">
  select * from(<include refid="dataSource"/>) q
  where q.id not in (
    (<include refid="removeRowIndex"/>)
    )
</select>
相关推荐
TDengine (老段)5 小时前
TDengine 数学函数 DEGRESS 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
TDengine (老段)5 小时前
TDengine 数学函数 GREATEST 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
安当加密5 小时前
云原生时代的数据库字段加密:在微服务与 Kubernetes 中实现合规与敏捷的统一
数据库·微服务·云原生
爱喝白开水a5 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
想ai抽5 小时前
深入starrocks-多列联合统计一致性探查与策略(YY一下)
java·数据库·数据仓库
武子康6 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
longgyy6 小时前
5 分钟用火山引擎 DeepSeek 调用大模型生成小红书文案
java·数据库·火山引擎
ytttr8736 小时前
C# 仿QQ聊天功能实现 (SQL Server数据库)
数据库·oracle·c#
盒马coding7 小时前
第18节-索引-Partial-Indexes
数据库·postgresql
dingdingfish7 小时前
关于Oracle RAC和ADG的学习资料
oracle·database·adg·rac·ha·dr·maa