日期:2014-05-17  浏览次数:20769 次

oracle有条件删除重复数据
现在oracle数据库有张表,数据如下。如何用一条SQL语句,删除重复数据,注册时间在1分钟之内的数据,都算重复数据。
姓名,学号,注册时间
张三,201111,2012-11-20 09:50:10
张三,201111,2012-11-20 09:50:15
张三,201111,2012-11-20 09:52:15
李四,201112,2012-11-20 10:30:50
李四,201112,2012-11-20 10:31:10

------解决方案--------------------
来了~!改之~!!

SELECT XM,XH,SJ FROM(
SELECT 
TO_CHAR(TO_DATE(SJ, 'YYYY-MM-DD HH24:MI:SS'), 'MISS') - 
TO_CHAR(TO_DATE(min(SJ) keep (DENSE_RANK first ORDER BY SJ) over(partition by XH), 'YYYY-MM-DD HH24:MI:SS'), 'MISS') AS FLG
,XM,XH,SJ,ROW_NUMBER()over(partition by XH ORDER BY SJ) as RN FROM TEST)
WHERE RN= 1 OR FLG >60