oracle常用sql

--备份tbluser的数据到tbluser_bak中
create table tbluser_bak as select * from tbluser; --此处不加as也行
--删除备份表的数据
truncate table tbluser_bak;

--还原表数据
insert into tbluser_bak select * from tbluser ;

--查看数据是否恢复
select * from tbluser_bak;
--查询重复数据不用having

select * from SCH_SC_OTHERTIME where PERSON_ID in(select PERSON_ID from (select PERSON_ID, DEPT_ID, NATURE , count(1)as num
from SCH_SC_OTHERTIME
group by PERSON_ID, DEPT_ID, NATURE ) where num>1)

--查询重复数据用having

select e.person_id, e.dept_id, e.nature
from sch_sc_othertime e
group by e.person_id, e.dept_id, e.nature
having count(*) > 1

--查看根据指定字段查询重复数据保留最大值

delete from sch_sc_weekresiduetime e
 where (e.person_id, e.dept_id, e.nature, e.weekdate, e.residuenumber) not in
       (select e.person_id,
               e.dept_id,
               e.nature,
               e.weekdate,
               max(e.residuenumber)
          from sch_sc_weekresiduetime e
         group by e.person_id, e.dept_id, e.nature, e.weekdate)
   and (e.person_id, e.dept_id, e.nature, e.weekdate) in
       (select e.person_id, e.dept_id, e.nature, e.weekdate
          from (select e.person_id,
                       e.dept_id,
                       e.nature,
                       e.weekdate,
                       count(1) as num
                  from sch_sc_weekresiduetime e
                 group by e.person_id, e.dept_id, e.nature, e.weekdate) e
         where e.num > 1);

--删除重复数据

delete from sch_sc_weekresiduetime e
 where (e.person_id, e.dept_id, e.nature, e.weekdate) in
       (select e.person_id, e.dept_id, e.nature, e.weekdate
          from (select e.person_id,
                       e.dept_id,
                       e.nature,
                       e.weekdate,
                       count(1) as num
                  from sch_sc_weekresiduetime e
                 group by e.person_id, e.dept_id, e.nature, e.weekdate) e
         where e.num > 1)
   and rowid not in (select max(rowid) from sch_sc_weekresiduetime);

--查看根据指定字段查询重复数据保留最大值

delete from sch_sc_weekresiduetime e
where (e.person_id, e.dept_id, e.nature,e.weekdate, e.residuenumber) not in
(select e.person_id, e.dept_id, e.nature,e.weekdate, max(e.residuenumber)
from sch_sc_weekresiduetime e
group by e.person_id, e.dept_id, e.nature,e.weekdate
having count(*) > 1)
and (e.person_id, e.dept_id, e.nature,e.weekdate) in
(select e.person_id, e.dept_id, e.nature,e.weekdate
from sch_sc_weekresiduetime e
group by e.person_id, e.dept_id, e.nature,e.weekdate
having count(*) > 1);

--删除重复数据

delete from sch_sc_weekresiduetime e
where (e.person_id, e.dept_id, e.nature,e.weekdate) in
(select e.person_id, e.dept_id, e.nature,e.weekdate
from sch_sc_weekresiduetime e
group by e.person_id, e.dept_id, e.nature,e.weekdate
having count(*) > 1)
and rowid not in (select max(rowid)
from sch_sc_weekresiduetime e
group by e.person_id, e.dept_id, e.nature,e.weekdate
having count(*) > 1);

 

posted on   小小小传说  阅读(5)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示