On Jul 7, 3:07 pm, Karen Tracey <kmtra...@gmail.com> wrote:
>
>
> > On Jun 29, 10:53 am, Steve Howell <showel...@yahoo.com> wrote:
> > > Hi, I have created a management command that populates some tables in
> > > a Postgres database, and I use the handy get_or_create() method in db/
> > > models/query.py.  I tried running a command recently where I had
> > > inadvertently left some foreign key references dangling around,
>
> Could you be a little more specific about what the error was in your code?

Sorry I never reported the error, but, of course, part of my problem
was that the error was caught by the try/except in Django code.

I did the following sequence, conceptually:

  1) I had a database with books and authors.
  2) I received a new feed of books.
  3) I cleaned the books table without cleaning the authors table.
  4) When I tried to import the first book, there was still a stale
author.
  5) Instead of getting the normal integrity error, I got the red
herring savepoint error.
  6) When I went back and cleaned BOTH tables, everything worked fine.


> From looking at the full get_or_create routine you include below it isn't
> immediately obvious to me where it might be raising an IntegrityError before
> the savepoint is created, yet it sounds like that is what is happening.  We
> need to understand how that is happening before figuring out what the right
> fix is.
>

If memory serves correctly, it was this line that raised the original
error:

                obj.save(force_insert=True)


Here's the code in more context:

            try:
                params = dict([(k, v) for k, v in kwargs.items() if
'__' not in k])
                params.update(defaults)
                obj = self.model(**params)
                sid = transaction.savepoint()
                obj.save(force_insert=True)
                transaction.savepoint_commit(sid)
                return obj, True
            except IntegrityError, e:
                transaction.savepoint_rollback(sid)
                try:
                    return self.get(**kwargs), False
                except self.model.DoesNotExist:
                    raise e



--~--~---------~--~----~------------~-------~--~----~
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 
django-users+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to