On 5/17/06, Adrian Holovaty <[EMAIL PROTECTED]> wrote:
>
> On 5/16/06, Elver Loho <[EMAIL PROTECTED]> wrote:
> > Let's take the poll sample. We've got the vote() view going on.
> >
> > choice.votes += 1
> > choice.save()
> >
> > Suppose we've got thread1 and thread2 going on (high-load website):
> >
> > choice.votes is originally 16
> >
> > thread1.choice.votes += 1
> > thread2.choice.votes += 1
> > thread1.choice.save()
> > thread2.choice.save()
> >
> > choice.votes _should_ be 18 now, but is it 18 or 17?
>
> You're right to point this out -- it'll probably be 17. That
> particular example is a bad example; it'd be better to do "UPDATE
> choices SET votes=votes+1 WHERE id=X", which would always increment
> rather than setting the value directly.

So the best practices workaround would be to write raw SQL instead?

Hm. I can do that. I was already planning on swapping the templating
engine for Kid. I like how Django's really loosely coupled :)


Elver

--~--~---------~--~----~------------~-------~--~----~
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
-~----------~----~----~----~------~----~------~--~---

Reply via email to