Please. Always, ALWAYS, give the PostgreSQL version and O/S when reporting
a problem.

First, WHAT IS THE POSTGRESQL VERSION?????
       WHAT IS THE O/S?????

       Then try this:
select a.ctid, a.id, a.field1,
          b.ctid, b.id, b.field1
  from some_table a,
         some_table b
 WHERE a.ctid <> b.ctid
   AND a.id = b.id;


On Tue, Dec 22, 2015 at 4:03 AM, Aleksander Łukasz <allll...@gmail.com>
wrote:

> Hi,
>
> a table in our database with about 3 million rows ended up in a state
> where its seems to have duplicated entries (duplicated primary key values):
>
> # \d some_table;
>                                    Table "public.some_table"
>  Column |            Type             |                        Modifiers
>
> --------+-----------------------------+---------------------------------------------------------
>  id     | integer                     | not null default
> nextval('some_table_id_seq'::regclass)
>  field1 | character varying(40)       |
>  field2 | character varying(128)      |
>  ts     | timestamp without time zone |
>
> Indexes:
>     "some_table_pkey" PRIMARY KEY, btree (id)
>     "ix_some_table_field1" btree (field1)
>     "ix_some_table_field2" btree (field2)
>     "ix_some_table_ts" btree (ts)
>
>
> # select id, field1, field2 from some_table where field1 is null and
> field2 is not null;
>    id    | field1 |            field2
> ---------+--------+----------------------------------
>  2141750 |        | some_value2
> (1 row)
>
>
> # select id, field1, field2 from some_table where id = 2141750;
>    id   | field1       |    field2
> ---------+-------------+----------------------------------
> 2141750 | some_value1   | some_value2
> (1 row)
>
> Another way this manifests itself it that running this:
>
> # update some_table
>    set field2 = field1
> where
>    id = 2141750;
>
> works perfectly fine (but doesn't change the result of the first two
> queries above),
> but this results in an error:
>
> # update some_table
>    set field2 = field1
> where
>    field1 is not null
>    and field2 is null
>    and ts between '2015-12-01' and '2015-12-02';
>
> ERROR:  duplicate key value violates unique constraint "some_table_pkey"
> DETAIL:  Key (id)=(2141750) already exists.
>
> Do you have any idea what could be happening and what measures should be
> undertaken to fix this issue? Thanks.
>
>


-- 
*Melvin Davidson*
I reserve the right to fantasize.  Whether or not you
wish to share my fantasy is entirely up to you.

Reply via email to