postgresql简介
postgresql是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ordbms),是以加州大学计算机系开发的postgres,4.2版本为基础的对象关系型数据库管理系统。postgres的许多领先概念只是在比较迟的时候才出现在商业网站数据库中。postgresql支持大部分的sql标准并且提供了很多其他现代特性,如复杂查询、外键、触发器、视图、事务完整性、多版本并发控制等。同样,postgresql也可以用许多方法扩展,例如通过增加新的数据类型、函数、操作符、聚集函数、索引方法、过程语言等。另外,因为许可证的灵活,任何人都可以以任何目的免费使用、修改和分发postgresql。
我们在使用postgresql数据库的时候,如果一张数据表在未做任何约束的情况下,很可能会出现几条完全一样的数据,即重复数据。如下图所示:
那么如果我们要删除其中的2条该怎么办呢?第一种我们可以清空表的内容,再使用insert into语句再将内容插入到表中。此方法可行,但对于专业人士来讲,并不推荐
第二种我们可以结合pg数据库中的ctid(和物理存储有关,指的是一条记录位于哪个数据块的哪个位移上面)来进行删除。这里我们使用依然先使用select语句进行查询。
这样我们就可以使用唯一标识的ctid对重复数据进行删除操作,使用以下两种方式都可以删除tb_5201351表中2条数据。
delete from tb_5201351 where ctid in ('(0,2)','(0,3)');
上面的方法原理是我们依次手工输入要删除指定ctid对应的数据,如果数据较多的话,我们还可以使用如下语句进行删除。
delete from tb_5201351 where ctid not in (select min(ctid) from tb_5201351);
执行后的结果如下图所示:
到此这篇关于postgresql 重复数据处理的操作方法的文章就介绍到这了,更多相关postgresql 重复数据处理内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!