Did you mean or(|) instead of and(&)?
I need SQL UNION for efficiency reasons (using UNION instead of SQL
generated by
models.Advertisement.objects.filter( Q(company__name__search="test") |
Q(contact__phone__istartswith="8495") is 60x faster in my case)

On Sep 17, 7:51 pm, Daniel Roseman <dan...@roseman.org.uk> wrote:
> On Sep 17, 3:39 pm, blumenkraft <vohs...@gmail.com> wrote:
>
> > Hi,
>
> > I have two querysets:
> > x = models.Advertisement.objects.filter(company__name__search =
> > "test")
> > y = models.Advertisement.objects.filter(contact__phone__istartswith =
> > "8495")
>
> > Is there any simple way to get union (using SQL UNION clause) of these
> > querysets?
>
> Use Q() objects:
>
> from django.db.models import Q
> union = models.Advertisement.objects.filter(
>     Q(company__name__search="test") &
>     Q(contact__phone__istartswith="8495")
> )
>
> --
> DR.
--~--~---------~--~----~------------~-------~--~----~
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