Hello all

I am using Django 0.96 with postgresql 8.1 and psycopg2. The error
handling does not work as I would expect it to. Specifically, anytime a
database error occurs, all subsequent calls to the database fails with
the error message "ProgrammingError: current transaction is aborted,
commands ignored until end of transaction block".

This causes unittesting to break, since the tearDown will try to use the
existing database connection, as well as giving me strange error
messages at other times. You vcan see an example of the latter at the
bottom of my mail.

I have found that I can eliminate the problem by substituting this line
            self.connection.set_isolation_level(1) # make transactions
transparent to all cursors
with this one
            self.connection.set_isolation_level(0)
in django/db/backends/postgresql_psycopg2/base.py

However, I am worried that whoever wrote that code did so for a reason ;-)

Can anyone tell me:

- If this is intended behavior or a bug.
- If my change is likely to break anything, and if so, if there is
another recommended solution

Yours,

u'Nis J\xf8rgensen'

Appendix:

As an example of the problem, see the following interactive session

./manage.py shell
Python 2.4.4 (#2, Apr  5 2007, 20:11:18)
[GCC 4.1.2 20061115 (prerelease) (Debian 4.1.1-21)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> from spider.models import Language
>>> Language.objects.create(isocode='xx')
<Language: xx>
>>> Language.objects.create(isocode='xx')
Traceback (most recent call last):
  File "<console>", line 1, in ?
  File "/usr/lib/python2.4/site-packages/django/db/models/manager.py",
line 79, in create
    return self.get_query_set().create(**kwargs)
  File "/usr/lib/python2.4/site-packages/django/db/models/query.py",
line 262, in create
    obj.save()
  File "/usr/lib/python2.4/site-packages/django/db/models/base.py", line
238, in save
    ','.join(placeholders)), db_values)
  File "/usr/lib/python2.4/site-packages/django/db/backends/util.py",
line 12, in execute
    return self.cursor.execute(sql, params)
IntegrityError: duplicate key violates unique constraint
"spider_language_isocode_key"
>>> Language.objects.create(isocode='yy')
Traceback (most recent call last):
  File "<console>", line 1, in ?
  File "/usr/lib/python2.4/site-packages/django/db/models/manager.py",
line 79, in create
    return self.get_query_set().create(**kwargs)
  File "/usr/lib/python2.4/site-packages/django/db/models/query.py",
line 262, in create
    obj.save()
  File "/usr/lib/python2.4/site-packages/django/db/models/base.py", line
238, in save
    ','.join(placeholders)), db_values)
  File "/usr/lib/python2.4/site-packages/django/db/backends/util.py",
line 12, in execute
    return self.cursor.execute(sql, params)
ProgrammingError: current transaction is aborted, commands ignored until
end of transaction block




--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to