IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 序运算,找出不符合连续递增的异常 -> 正文阅读

[大数据]序运算,找出不符合连续递增的异常

【问题】

ID????DDATE
1?????2013/5/7
2?????2013/8/6
3?????2013/6/12
4?????2013/12/1
一个表当中??ID??1??2??3??4?这样,时间也应该是从小到大,现在想把时间不是从小到大的找出来。?比如:2???2013/8/6和3??2013/6/12??就不对,把这两条找出来?

【回答】

?????? 按照问题描述,可能有两种情况,一是只比较相邻记录;二是比较当前记录与前后所有记录(如当3比2大但比1小时,应将1 2 3都查出来),在ORACLE中实现这两种情况都要借助窗口函数使用子查询来完成,分别可以这样写:

(1)?? 只比较相邻:

SELECT id, ddate
? FROM (select id,ddate,
??????? lag(ddate,1) over(order by id) as d1,
??????? lead(ddate,1) over(order by id) as d2
??????? from T0042)
?WHERE d1 > ddate OR d2 < ddate

(2)?? 比较所有:

WITH T1 as (
select id,ddate,max(ddate)over(order by id) d1
from t0042),T2 as (
select id,min(ddate)over(order by id desc) d2
from t0042)
select T1.id,T1.ddate
from T2,T1
WHERE T1.id=T2.id and (t1.ddate<>T1.d1 or t1.ddate<>T2.d2)

SQL的写法较复杂难懂,其主要是因为集合无序,要用窗口函数拼出子查询造出次序。如果集合有序的话,上述运算就容易写了。用SPL完成这个运算会直观一些,具体脚本如下:

A
1$select ID,DDATE from t0042 order by ID
2=A1.select(DDATE<DDATE[-1] || DDATE>min(DDATE[0,1]))
3=A1.select(DDATE!=max(DDATE[,0]) || DDATE!=min(DDATE[0,]))

A1:sql取数,按照ID排序

A2:比较相邻,选出比上一个DDATE小,或者比后一个DDATE大的记录

A3:比较所有,选出不比前面所有DDATE都大,或者不比后面所有DDATE都小的记录

写好的脚本如何在应用程序中调用,可以参考Java 如何调用 SPL 脚本

?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-15 00:05:37  更:2022-04-15 00:11:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 12:38:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码