问题真难,高手来帮助一下吧!送1000分都可以。

hejiwang 2005-12-15 02:01:42
表结构如下
ID EVT_OBJECT glh_ID xc begin_dt end_dt JG
1 1000.001 AAAA Y 2005-10-11 2005-11-11 1
2 1000.001 AAAA M 2005-10-10 2005-11-10 1
3 1000.001 AAAA W 2005-10-11 2005-11-11 7
4 1000.001 BBBB Y 2005-10-10 2005-11-10 1

去掉重复记录,条件如下:
1,如果glh_id相同,取xc=Y(Y>M>W>D)记录,如果xc相同,取begin_dt大的记录,
2,如果glh_id不相同,比较xc的大小(Y>M>W>D),如果xc相同,取begin_dt大的记录。
3,按条件上面记录最后留下ID=1的记录,其它记录都得删除了。
...全文
226 点赞 收藏 11
写回复
11 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
linxi27 2005-12-17
高手,頂一下
回复
软侠 2005-12-17
有點小的改動,我上面給出的刪除語句中最後的條件還可以簡化,有些多余的條件可以不要,修改後如下:delete from Test_tbl t1
Where
NOT EXISTS(
select 1
from
(
select EVT_OBJECT,xc,begin_dt,rowid,
row_number() over(Partition by EVT_OBJECT ORDER BY decode(xc,'Y',4,'M',3,'W',2,'D',1) DESC) rn1
,row_number() over(Partition by EVT_OBJECT,xc ORDER BY begin_dt DESC) rn2
from Test_tbl
) t2
where t2.rn1=1 and t2.rn2=1
and t1.rowid=t2.rowid
);
回复
tangtangno1 2005-12-17
//一时疏忽,应该这么写

delete table t1
where (ID)not in(select id from(select ID from table where EVT_OBJECT=t1.EVT_OBJECT order by xc DESC,begin_dt DESC) where rownum=1)
回复
tangtangno1 2005-12-17
表结构如下
ID EVT_OBJECT glh_ID xc begin_dt end_dt JG
1 1000.001 AAAA Y 2005-10-11 2005-11-11 1
2 1000.001 AAAA M 2005-10-10 2005-11-10 1
3 1000.001 AAAA W 2005-10-11 2005-11-11 7
4 1000.001 BBBB Y 2005-10-10 2005-11-10 1

去掉重复记录,条件如下:
1,如果glh_id相同,取xc=Y(Y>M>W>D)记录,如果xc相同,取begin_dt大的记录,
2,如果glh_id不相同,比较xc的大小(Y>M>W>D),如果xc相同,取begin_dt大的记录。
3,按条件上面记录最后留下ID=1的记录,其它记录都得删除了。
==================================================
按照楼主所说条件,1和2应该合并起来这么说:按照(xc,begin_dt)排列取较大者。而3却又没提EVT_OBJECT的事情

//这么些是不是看着简单一些呢
delete table t1
where (ID)not in(select id from(select ID from table where id=t1.id order by xc DESC,begin_dt DESC) where rownum=1)

回复
软侠 2005-12-16
樓上的幾位給的代碼太復雜了,而且有些還不符合樓主的羅輯意義,樓主所說的兩個條件,進行邏輯意義的歸並後,應為:在EVT_OBJECT相同的記錄中,取出xc值最大(Y>M>W>D)的記錄(不管glh_id是否相同),如果取出的xc值最大的記錄不止一條,則隻取出begin_dt值最大的一條,其它的記錄全刪掉。
我的參考代碼如下:
--創建測試表和數據
SQL>Create table Test_Tbl(ID int,EVT_OBJECT varchar2(10),glh_ID varchar2(5),xc char(1),begin_dt date,end_dt date,JG int);
SQL> begin
insert into test_tbl values(1,'1000.001','AAAA','Y',to_date('2005-10-11','YYYY-MM-DD HH24:MI:SS'),to_date('2005-11-11','YYYY-MM-DD HH24:MI:SS'),1);
insert into test_tbl values(2,'1000.001','AAAA','M',to_date('2005-10-10','YYYY-MM-DD HH24:MI:SS'),to_date('2005-11-10','YYYY-MM-DD HH24:MI:SS'),1);
insert into test_tbl values(3,'1000.001','AAAA','W',to_date('2005-10-11','YYYY-MM-DD HH24:MI:SS'),to_date('2005-11-11','YYYY-MM-DD HH24:MI:SS'),7);
insert into test_tbl values(4,'1000.001','BBBB','Y',to_date('2005-10-10','YYYY-MM-DD HH24:MI:SS'),to_date('2005-11-10','YYYY-MM-DD HH24:MI:SS'),1);
end;

--顯示插入後的數據
SQL>select * from Test_Tbl;

ID EVT_OBJECT GLH_ID XC BEGIN_DT END_DT JG
---------- ---------- ----- -- -------------- -------------- ----------
1 1000.001 AAAA Y 11-10月-05 11-11月-05 1
2 1000.001 AAAA M 10-10月-05 10-11月-05 1
3 1000.001 AAAA W 11-10月-05 11-11月-05 7
5 1000.001 BBBB Y 10-10月-05 10-11月-05 1

--大家可以看看上面的記錄,依樓主的要求,刪除重復記錄後得到的結果應該是:
ID EVT_OBJECT GLH_ID XC BEGIN_DT END_DT JG
1 1000.001 AAAA Y 11-10月-05 11-11月-05 1

--現在我使用下面的語句進行刪除,看最後結果是否符合要求
--使用刪除語句
SQL>delete from Test_tbl t1
Where
NOT EXISTS(
select 1
from
(
select EVT_OBJECT,xc,begin_dt,rowid,
row_number() over(Partition by EVT_OBJECT ORDER BY decode(xc,'Y',4,'M',3,'W',2,'D',1) DESC) rn1
,row_number() over(Partition by EVT_OBJECT,xc ORDER BY begin_dt DESC) rn2
from Test_tbl
) t2
where t2.rn1=1 and t2.rn2=1
and t1.EVT_OBJECT=t2.EVT_OBJECT and t1.xc=t2.xc and t1.begin_dt=t2.begin_dt
and t1.rowid=t2.rowid
);
--再查看結果
SQL>select * from test_tbl;

ID EVT_OBJECT GLH_I X BEGIN_DT END_DT JG
---------- ---------- ----- - -------------- -------------- ----------
1 1000.001 AAAA Y 11-10月-05 11-11月-05 1
--從上結果可以看出,則好符合要求了
回复
hlp912 2005-12-16
不错。
回复
Renkey 2005-12-15
强,
用PL/SQL更好。
回复
ab5669 2005-12-15
select ID, EVT_OBJECT, glh_ID,
(case xc when '4' then 'Y'
when '3' then 'M'
when '2' then 'W'
when '1' then 'D'
else ' '
end) as xc , begin_dt, end_dt, JG
from (
select rownum,glh_ID, xc, begin_dt
from
(
select glh_ID, xc, begin_dt
(select glh_ID, max(xc) as xc
from
(
select glh_ID, (case xc when 'Y' then '4'
when 'M' then '3'
when 'W' then '2'
when 'D' then '1'
else '0'
end) as xc,
max(begin_dt) as begin_dt
from tablename
group by glh_ID, xc
)
group by glh_ID
) temp1,
(
select ID, EVT_OBJECT, glh_ID, (case xc when 'Y' then '4'
when 'M' then '3'
when 'W' then '2'
when 'D' then '1'
else '0'
end) as xc , begin_dt, end_dt, JG
from tablename
) temp2
where temp1.glh_ID=temp2.glh_ID and temp1.xc=temp2.xc
)
order by xc desc, begin_dt desc
)
where rownum=1
回复
cqm2008 2005-12-15
高手呀,顶一下
回复
子陌红尘 2005-12-15
删除操作:
-----------------------------------------------------------------------------------------------------------------
delete from 表 a
where
exists(select 1
from 表
where
glh_ID<>a.glh_ID
and
decode(xc,'Y',4,'M',3,'W',2,'D',1)>decode(a.xc,'Y',4,'M',3,'W',2,'D',1)
or
(decode(xc,'Y',4,'M',3,'W',2,'D',1)=decode(a.xc,'Y',4,'M',3,'W',2,'D',1) and begin_dt>a.begin_dt))
or
exists(select 1
from 表
where
glh_ID= a.glh_ID
and
decode(xc,'Y',4,'M',3,'W',2,'D',1)>decode(a.xc,'Y',4,'M',3,'W',2,'D',1)
or
(decode(xc,'Y',4,'M',3,'W',2,'D',1)=decode(a.xc,'Y',4,'M',3,'W',2,'D',1) and begin_dt>a.begin_dt))
回复
子陌红尘 2005-12-15
select
a.*
from
表 a
where
not exists(select 1
from 表
where
glh_ID<>a.glh_ID
and
decode(xc,'Y',4,'M',3,'W',2,'D',1)>decode(a.xc,'Y',4,'M',3,'W',2,'D',1)
or
(decode(xc,'Y',4,'M',3,'W',2,'D',1)=decode(a.xc,'Y',4,'M',3,'W',2,'D',1) and begin_dt>a.begin_dt))
and
not exists(select 1
from 表
where
glh_ID= a.glh_ID
and
decode(xc,'Y',4,'M',3,'W',2,'D',1)>decode(a.xc,'Y',4,'M',3,'W',2,'D',1)
or
(decode(xc,'Y',4,'M',3,'W',2,'D',1)=decode(a.xc,'Y',4,'M',3,'W',2,'D',1) and begin_dt>a.begin_dt))
回复
发帖
基础和管理
创建于2007-09-28

1.7w+

社区成员

Oracle 基础和管理
申请成为版主
帖子事件
创建了帖子
2005-12-15 02:01
社区公告
暂无公告