Thank you Tim,

Seems to work now with:
w=240
pricelisttable_set.extra(where=["""(table_pricelisttable.width - %s)
>= ( SELECT Min(Abs(pl.width - %s)) FROM table_pricelisttable pl)
"""], params=[w, w])[0]


On 7/29/07, Tim Chase <[EMAIL PROTECTED]> wrote:
>
> > In pure sql  we can do :
> > "select min(abs(width-150)) from quote_pricelisttable where name_id =
> > 1 and width >= 240-150 and width <=240+150;"
> >
> > How to make it work properly from django ORM?
>
> Did you try playing with the extra() call I included in my
> previous email?  It should do what you describe, and doesn't
> require a fixed window such as you describe not wanting.
>
> While it does rely on using some SQL, it does so through the
> Django ORM and it should be fairly portable SQL (the "Abs()"
> function is usually the "Abs()" function on most SQL engines).
> The code I included (minus any syntax errors) should have found
> the items from the given table where they were the minimum
> distance from the target value.
>
>   w = 240 # target width to find the closest...comes from user
>   results = PriceList.objects.extra(where=["""
>       Abs(app_pricelist.width - %s) = (
>          SELECT Min(Abs(pl.width - %s))
>          FROM app_pricelist pl
>          )
>       """], params=[w, w])
>
> The results are a Django ORM query object that can be further
> filtered, sliced, sorted, and iterated over with no problems.
> While it can be done in pure python/django rather than SQL, it
> would require dragging the whole PriceList across the wire and
> filtering locally--a much slower proposition than simply letting
> the DB do the work for you and shipping you just the exact
> results you want.
>
> -tim
>
>
>
>
> >
>


-- 
--
Michael

--~--~---------~--~----~------------~-------~--~----~
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?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to