sql >> Databasteknik >  >> RDS >> PostgreSQL

Fortsätter en transaktion efter fel med primärnyckeln

Du kan också använda SAVEPOINTs i en transaktion.

Pythonisk pseudokod illustreras från applikationssidan:

database.execute("BEGIN")
foreach data_row in input_data_dictionary:
    database.execute("SAVEPOINT bulk_savepoint")
    try:
        database.execute("INSERT", table, data_row)
    except:
        database.execute("ROLLBACK TO SAVEPOINT bulk_savepoint")
        log_error(data_row)
        error_count = error_count + 1
    else:
        database.execute("RELEASE SAVEPOINT bulk_savepoint")

if error_count > error_threshold:
    database.execute("ROLLBACK")
else:
    database.execute("COMMIT")

Edit:Här är ett faktiskt exempel på detta i aktion i psql baserat på en liten variation av exemplet i dokumentationen (SQL-satser med prefixet ">"):

> CREATE TABLE table1 (test_field INTEGER NOT NULL PRIMARY KEY);
NOTICE:  CREATE TABLE / PRIMARY KEY will create implicit index "table1_pkey" for table "table1"
CREATE TABLE

> BEGIN;
BEGIN
> INSERT INTO table1 VALUES (1);
INSERT 0 1
> SAVEPOINT my_savepoint;
SAVEPOINT
> INSERT INTO table1 VALUES (1);
ERROR:  duplicate key value violates unique constraint "table1_pkey"
> ROLLBACK TO SAVEPOINT my_savepoint;
ROLLBACK
> INSERT INTO table1 VALUES (3);
INSERT 0 1
> COMMIT;
COMMIT
> SELECT * FROM table1;  
 test_field 
------------
          1
          3
(2 rows)

Observera att värdet 3 infogades efter felet, men fortfarande inne i samma transaktion!

Dokumentationen för SAVEPOINT finns på http://www.postgresql.org/docs/8.4/static/sql-savepoint.html.



  1. Hur vet jag om min PostgreSQL-säkerhetskopia är bra?

  2. Har inte databaslås! i android

  3. Fel:Det finns tabellutrymme för tabell xxx. Vänligen KASSA tabellutrymmet före IMPORT

  4. Java - hitta den första orsaken till ett undantag