Truly amazing. I would have never guessed that the OR operator would
combine two querysets. How does that work?

Thanks for your help. You solved my problem.
J



Russell Keith-Magee wrote:
> On Sun, Feb 8, 2009 at 8:03 AM, J <jobce...@gmail.com> wrote:
>   
>> The idea is to be able to query all the items that have a specific 'group'
>> record chosen, as well as all items that don't have anything set. Since some
>> of them can be NULL or None, how do I go about selecting in a query both the
>> items that are NULL, as well as the items that are linked to a specific
>> 'group' in the related table?
>>
>> This does not work:
>> qs = menuitem.objects.all().filter(group__in=[None, 1])
>>
>> This works:
>> qs = menuitem.objects.all().filter(group=None)
>>
>> This works:
>> qs = menuitem.objects.all().filter(group=1)
>>     
>
> The confusion here is the result of a little concept leakage on the
> part of the Django ORM.
>
> In SQL, you can't actually ask for a field that is " = NULL", because
> by definition, _nothing_ is equal to NULL. Django helps out here by
> rolling out "group=None" filters to the SQL "group IS NULL"
>
> When you ask for the query group__in=[None, 1], this will roll out as
> "group IN (NULL, 1)", which obviously won't work for the NULL case.
>
> What you need to do is use an OR to combine your the two queries that
> work, making a special case of the NULL option:
>
> qs = menuitem.objects.all().filter(group=None) |
> menuitem.objects.all().filter(group=1)
>
> If you have multiple non-null groups that you want to compare to, you
> can use the __in operator on the second clause:
>
> qs = menuitem.objects.all().filter(group=None) |
> menuitem.objects.all().filter(group__in=[1,2])
>
> You just can't include the None in the __in - it needs to be made a
> special case.
>
> Yours,
> Russ Magee %-)
>
> >
>
>   


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