Hello,one remote user reported a problem and i was surprised to witness the 
following behaviour.
It is on postgresql 8.3.3

dynacom=# BEGIN;
BEGIN
dynacom=# 
dynacom=# 
dynacom=# insert into xadmin(appname,apptbl_tmp,gao,id,comment)
dynacom-# 
values('PMS','overhaul_report_tmp','INSERT',nextval('overhaul_report_tmp_pkid_seq'),'
 zzz ');
INSERT 0 1
dynacom=# 
dynacom=# insert into 
items_tmp(id,vslwhid,serialno,rh,lastinspdate,classused,classsurvey,classsurveydate,classduedate,
dynacom(# 
classpostponed,classcomment,defid,machtypecount,totalrh,comment,attachments,lastrepdate,pmsstate,xid,classaa)
 
dynacom-# select 
id,vslwhid,serialno,rh,lastinspdate,classused,classsurvey,classsurveydate,classduedate,classpostponed,
dynacom-# 
classcomment,defid,machtypecount,totalrh,comment,attachments,lastrepdate,pmsstate,currval('xadmin_xid_seq'),
dynacom-# classaa from items where id=1261319;
INSERT 0 1
dynacom=# -- in the above 'xadmin_xid_seq' has taken a new value in the first 
insert
dynacom=# SELECT currval('xadmin_xid_seq');
 currval 
---------
   61972
(1 row)
dynacom=# SELECT id from items_tmp WHERE id=1261319 AND xid=61972;
   id    
---------
 1261319
(1 row)
dynacom=# -- ok this is how it should be
dynacom=# SELECT id from items_tmp WHERE id=1261319 AND 
xid=currval('xadmin_xid_seq');
 id 
----
(0 rows)
dynacom=# -- THIS IS INSANE

This code has run fine (the last SELECT returns exactly one row) for 5,409,779 
total transactions thus far, in 70 
different postgresql slave installations (mixture of 8.3.3 and 8.3.13) (we are 
a shipping company), 
until i got this error report from a user yesterday.

What could be causing this? How could i further investigate this? Unfortunately 
the remote installations are neither 
physically accessible nor by TCP/IP accesible (comms are done via UUCP and 
administration via minicom, and the costs are 
just huge 5 USD/min for 33Kbits/sec). So, i would exhaust all posibilities 
before deciding to ship a new postgresql version there,
and remotely upgrade, physically travel to the ship or even trying to do a 
backup/initdb/restore in the existing version.
Any help would be really really appreciated.

Also, as you might have understood, upgrading, although generally a good idea, 
does not apply so easily in our case.

Some information about the schema :

dynacom=# \d xadmin    
                                          Table "public.xadmin"
   Column   |            Type             |                          Modifiers  
                         
------------+-----------------------------+--------------------------------------------------------------
 xid        | bigint                      | not null default 
nextval(('xadmin_xid_seq'::text)::regclass)
 appname    | text                        | not null
 apptbl_tmp | text                        | not null
 gao        | character varying(40)       | not null
 id         | integer                     | not null
 comment    | text                        | 
 state      | text                        | not null default 'NPY'::text
 arcedon    | timestamp without time zone | default now()
Indexes:
    "xa_pk" PRIMARY KEY, btree (xid)
    "xa_appname_idx" btree (appname)
    "xa_appname_state_idx" btree (appname, state)
    "xa_state_idx" btree (state)


dynacom=# \d items_tmp 
               Table "public.items_tmp"
     Column      |          Type          | Modifiers 
-----------------+------------------------+-----------
 id              | integer                | not null
 vslwhid         | integer                | 
 serialno        | character varying(40)  | 
 rh              | integer                | 
 lastinspdate    | date                   | 
 classused       | integer                | 
 classaa         | text                   | 
 classsurvey     | character varying(100) | 
 classsurveydate | date                   | 
 classduedate    | date                   | 
 classpostponed  | date                   | 
 classcomment    | text                   | 
 defid           | integer                | 
 machtypecount   | integer                | 
 totalrh         | integer                | 
 comment         | character varying(200) | 
 attachments     | text[]                 | 
 lastrepdate     | date                   | 
 pmsstate        | character varying(200) | 
 xid             | bigint                 | not null
Indexes:
    "it_tmp_pk" PRIMARY KEY, btree (id, xid)
Foreign-key constraints:
    "items_tmp_xid_fkey" FOREIGN KEY (xid) REFERENCES xadmin(xid)


-
Achilleas Mantzios
IT DEPT

-- 
Sent via pgsql-sql mailing list (pgsql-sql@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-sql

Reply via email to