Re: DBD::Pg transaction issues - Mailing list pgsql-sql
| From | Raj Mathur |
|---|---|
| Subject | Re: DBD::Pg transaction issues |
| Date | |
| Msg-id | 16017.14581.156730.440857@mail.linux-delhi.org Whole thread Raw |
| In response to | Re: DBD::Pg transaction issues (Rajesh Kumar Mallah <mallah@trade-india.com>) |
| Responses |
Re: DBD::Pg transaction issues
Re: DBD::Pg transaction issues |
| List | pgsql-sql |
Hi Rajesh,
>>>>> "Rajesh" == Rajesh Kumar Mallah <mallah@trade-india.com> writes:
Rajesh> Dear Raju,
Rajesh> All subsequest statements (DML/DDL/SELECT) are ignored Rajesh> after the first ERROR caused by any
statementin the Rajesh> transaction. the current transaction must be rollbacked Rajesh> and new one started.
Rajesh> I can think of two approaches:
Rajesh> a) Prevent the error situation from arising may be by Rajesh> first querying if the reference exists.
Which is what I'm doing now; it's an inelegant and inefficient
solution.
Rajesh> b) commit when the operation succeds and rollback when Rajesh> there is ERROR from sql.
That's not an alternative, since I need to commit either all the
record in the file or none of them.
Rajesh> In perl-DBI eval is gnerally used for catching such SQLs Rajesh> without aborting the program.
Am using eval's, but the transaction gets aborted in any case. The
eval is only useful for my program to trap the error. I'm trying to
find out how I can prevent the transaction mechanism from treating
errors on the database as logical errors.
So is there no way to prevent PostgreSQL (or DBI) from aborting the
current transaction if an operation on the database fails?
Regards,
-- Raju
Rajesh> while (true ) {
Rajesh> eval { <DBD::Pg operations here> }; if ($@) { $dbh -> Rajesh> commit(); } else { $dbh -> rollback(); } }
Rajesh> in both cases you loose on performance in forfer case to Rajesh> to checking overhead and in laters
repeatedcomitting.
Rajesh> regds mallah.
Rajesh> On Monday 07 Apr 2003 10:01 am, Raj Mathur wrote: >> Hi, >> >> Am using DBD::Pg with PostgreSQL
7.2.3,Perl 5.8.0. I have a >> set of updates to a table which has (a) references to another >> table and (b)
possiblyduplicates. >> >> The data is in a text file, which is read record by record and >> appended to the
databasetable. A transactions spans the >> complete reading of the text file. >> >> If the cross-reference
fieldin the file doesn't exist in the >> referenced table I want to ignore the record. >> >> If the record
alreadyexists in the table I want to perform >> some updates to the existing data. >> >> The problem is that the
firstrecord in the text file that has >> an invalid reference, or one that already exists, causes the >>
transactionto abort and all subsequent updates from the file >> to fail. Is there any way to tell DBI/PostgreSQL
thatit >> should continue the transaction until the program directs it to >> commit/rollback? >> >> Tried the
followingso far: >> >> Set RaiseError to null. No effect. >> >> Currently manually checking for
duplicates/missingreferenced >> records and taking appropriate action when found. Pretty >> inelegant. >> >>
Pseudocode: >> >> open text file begin transaction while read text record write >> into table if write failed due
toduplicate read existing >> record update values in existing record rewrite record else if >> write failed due to
missingreference ignore record else mark >> file as bad >> >> if file not bad commit else rollback >> >>
Hopethis is the right list to be asking on. >> >> Regards, >> >> -- Raju
--
Raj Mathur raju@kandalaya.org http://kandalaya.org/ It is the mind that moves