firebird中删除多列重复的数据

在Firebird数据库中,由于没有内置的行ID,删除多列重复数据相对复杂。通常做法是使用临时表,通过自增ID字段模拟Oracle中的行ID。然而,Firebird的临时表功能有限,需要借助Generator和Trigger实现自增。本文介绍了一种策略,通过创建全局临时表,结合事务处理,利用表连接来删除重复数据,避免了`IN`子句的限制。
摘要由CSDN通过智能技术生成

原本不复杂,一条sql语句就可以完成。思路是先根据列分组,找出分组后数据都于一条的,然后从中删除除了行id最小的其他数据。Oracle中即时字段中没有能表示行id的,每行都自带一个rowid,sql语句:

select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)

但是firebird中没有自带的行id,那就用个临时表,增加一个自增的id字段,然后把其他所有数据拷贝到临时表中。但是firebird临时表用法也是比较奇葩,也没有像mysql中那样的 auto increament的功能,只能用个generator在弄个trigger,来模拟auto increasement。资料又少,用firebird有点坑,sql脚本如下:

-- 存储过程用于删除刷卡信息表中的重复数据,然后把以前索引改为唯一性索引
-- 创建临时表,增加行id,用于删除重复数据
create global temporary table temp_door_swipe_table (
id integer not null,
device_id varchar(50),
card_id varchar(20),
user_id varchar(50),
io_fg smallint,
swipe_time timestamp,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值