手抄报 安全手抄报 手抄报内容 手抄报图片 英语手抄报 清明节手抄报 节约用水手抄报

工作小技巧--Oracle之row_number() over() 使用

时间:2024-10-14 06:20:59

1、业务需求场景描述:我们有一张业务表,其中每条记录代表一辆车在某一天某一个特定小时的经纬度信息,我们需要从中抽取每一辆车在每一天最后上报的经纬度信息(此处需要注意的是各车辆在某天最后上报经纬度的小时并不相同)。图1示:我们的业务表建表语句图2示:我们的业务表数据展示图3示:我们最后期望得到的数据展示

工作小技巧--Oracle之row_number() over() 使用
工作小技巧--Oracle之row_number() over() 使用
工作小技巧--Oracle之row_number() over() 使用

2、根据需求,我们先在查询结果中对每一辆车每一天上报的多条数据进行编号,这个编号数据就需要使用 row_number() over() 挣窝酵聒函数来获取:我们根据车牌号、年、月、日对结果集进行分组,并按照小时进行倒序排序。SQL语句为:select carposinfo.*, row_number() over(partition by carno,cyear, cmonth, cday order by chour desc) as seq from carposinfo

工作小技巧--Oracle之row_number() over() 使用
工作小技巧--Oracle之row_number() over() 使用

3、有了上面获取的数据,我们就可以根据编号进行过滤,我们佯镧诱嚣只需获取所有编号=1的行数据即可,这里需要使用一个子查询,SQL语句为:select carno, cyear, cmonth, cday, clon, clat from (-- 子查询,即上面我们获取数据进行编号的查询语句select carposinfo.*, row_number() over(partition by carno, cyear, cmonth, cday order by chour desc) as seq from carposinfo )where seq = 1 order by carno, cyear, cmonth, cday

工作小技巧--Oracle之row_number() over() 使用
工作小技巧--Oracle之row_number() over() 使用

4、总结:通过 Oracle 为我们提供的这个函数 row_number() over() 我们可以对查询结果集添加一列编号数据,并通过这列编号对结果集再次进行过滤或其他业务处理。

© 手抄报圈