Hey Victor, I can think that a trivial way (I am not sure if it is the best) to do that is to overwrite the save() method of your model:
class MyModel(models.Model): title = models.CharField(max_length=100) only_me = models.Boolean(default=False) def save(self): if self.only_me: only_me_true = MyModel.objects.filter(only_me=True) for obj in only_me_true: obj.only_me = False obj.save() MyModel.save(self) I would go for that solution. It is easy to implement, it seems clean and it is easy to test as well. Cheers dude! Gabriel de Carvalho Nogueira Reis Software Developer +44 7907 823942 On Sat, Jan 16, 2010 at 12:22 AM, Victor Loureiro Lima < victorloureirol...@gmail.com> wrote: > Here is the deal: > > class MyModel ( models.Model ): > title = models.CharField( max_length = 100 ) > only_me = models.BooleanField( default = False ) > > Question: Whats the proper way to guarantee that no matter how many > MyModel's are available in the database, only one of them > will have the only_me set as True? To further clarify things: In the admin, > whenever I check the only_me checkbox, and save my model, all other models > of this class will have to have its own only_me field set to false. > > As far as I know, there is no other way of doing this unless I iterate > over all MyModel' s objects and uncheck them if they are checked, save them, > then afterwards check the model that I am actually saving setting the > only_me field to True. > > I tried doing this on the actual save() of the model, no success. > Everytime I called save on iterated objects, I, of course, got the maximum > recursive depth error thrown at me. > Fair enough, I quickly thought about signals, hooking my function to > post_save(), however I inevitabilly stumbled upon the same > problem: When I called save() on the iterated objects the post_save signal > got sent, I would step again in the same function, thus > no cookie for me. > I jumped over to overriding AdminForm' s save() method, so that I would > iterate there on the models unchecking them if necessary, and them returning > the proper object, but I stopped that and I said to myself that I must be > doing something really stupid, so Im coming to you guys: What would the > propper way of doing this? > > Thanks in Advance, > Victor Lima > > -- > You received this message because you are subscribed to the Google Groups > "Django users" group. > To post to this group, send email to django-us...@googlegroups.com. > To unsubscribe from this group, send email to > django-users+unsubscr...@googlegroups.com<django-users%2bunsubscr...@googlegroups.com> > . > For more options, visit this group at > http://groups.google.com/group/django-users?hl=en. > >--
You received this message because you are subscribed to the Google Groups "Django users" group.
To post to this group, send email to django-us...@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.