当前位置: 代码迷 >> Oracle开发 >> 求一条SQL 想不出来了,该怎么处理
  详细解决方案

求一条SQL 想不出来了,该怎么处理

热度:140   发布时间:2016-04-24 06:29:28.0
求一条SQL 想不出来了
ID    DATE
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  就不对   把这两条找出来 
------解决思路----------------------
本帖最后由 bw555 于 2015-01-26 14:54:17 编辑
SELECT ID,DATE FROM(
select id,DATE,
lag(DATE,1,DATE)OVER (ORDER BY ID) as PREDATE
lead(DATE,1,DATE)OVER (ORDER BY ID) as NEXTDATE
from T
) WHERE PREDATE>DATE OR NEXTDATE<DATE

------解决思路----------------------
;WITH CTE(ID,DATE) AS(
SELECT 1,'2013/05/07' UNION ALL
SELECT 2 ,'2013/08/06' UNION ALL
SELECT 3  ,   '2013/06/12' UNION ALL
SELECT 4   ,  '2013/12/01' UNION ALL
SELECT 5,'2014/01/22'
)
SELECT * FROM CTE AS A
WHERE EXISTS(SELECT 1 FROM CTE AS B WHERE A.DATE<B.DATE AND A.ID>B.ID)

------解决思路----------------------
确保你的date列是date类型或者格式标准的字符类型,
要不然不能正常排序
select t.d,t.date from 
(select d,date,rownum rn1,
            row_number() over(partition by d,date
             order by t.date) rn2
from tablename) t
where  rn1<>rn2;
------解决思路----------------------
分别以ID、DATE排序,然后编号,以编号比较两次的结果,不同ID、DATE的则是你要的
SELECT T1.ID, T1.DATE
  FROM (SELECT ID, DATE, ROWNUM R FROM TABLE_NAME ORDER BY ID) T1,--以id排序
       (SELECT ID, DATE, ROWNUM R FROM TABLE_NAME ORDER BY DATE) T2--以date排序
 WHERE T1.R = T2.R--按照编号连接
   AND T1.ID <> T2.ID --值不相等的

------解决思路----------------------
按照问题描述,可能有两种情况,一是只比较相邻记录;二是比较当前记录与前后所有记录(如当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的写法较复杂难懂,其主要是因为集合无序,要用窗口函数拼出子查询造出次序。如果集合有序的话,上述运算就容易写了。可以试试润乾公司的免费产品集算器,上述运算可以很直观地写出来:

        集算器提供JDBC接口,可以象数据库一样嵌入到应用程序中,用起来很简单。
  相关解决方案