Thanks!  Very helpful!

Any idea where a very experienced SQL coder can find a few details
beyond the three pages of model/queryset documentation?  Such as
information on a) SQL CASE statements (or equivalent), b) performing
LEFT JOINs (or equivalent).  Would studying the source code be my best
option?



On May 1, 2:03 pm, Malcolm Tredinnick <malc...@pointy-stick.com>
wrote:
> On Fri, 2009-05-01 at 10:48 -0700, jrs_66 wrote:
> > Hi,
>
> > Any pointers as to where I could find any info about performing a SQL
> > CASE statement using Django?  Even more fundamental... is there really
> > no way of doing a LEFT OUTER JOIN in Django (other than terribly
> > sloppy role your own hacks)?  Does anyone know of any more complete
> > model/queryset docs out there, other than the 3 pages Django offers?
>
> Your point of view is a little skewed here -- it's not particularly
> useful to think in terms of "how do I turn this SQL into Python".
>
>  Django's ORM provides a way to map particular pieces of Python
> functionality onto the persistent storage layer, which happens to be (by
> default at the moment) SQL databases. The goal isn't to provide every
> piece of SQL in an equivalent form. Rather, the goal is to provide a way
> to do various things that are useful at the Python level.
>
> So what's the model-related situation where a case-statement is going to
> be necessary? I know some exist, but I'm interested in which particular
> problem you're trying to solve so that we can help with a solution that
> fits well with Django. Right now, there is no situation where Django
> creates a "CASE" clause. Maybe in the future, if there's a common-enough
> functional situation that requires it, it could be added. Providing some
> context here will be useful.
>
> If you know precisely the SQL you want to write, then use SQL to conduct
> the query. It's a perfectly fine language for that and it would be
> redundant to to duplicate that in Django.
>
> As for left outer joins, Django uses them when it's necessary for the
> query and uses inner joins at other times. This is a case where the ORM
> does the right thing to implement the Python functionality and the
> caller doesn't have to worry about it.
>
> So what is the specific problem you are trying to solve that requires
> explicitly specifying an outer join? Once again, details will help us to
> help you.
>
>
>
> > Also, am I alone in being a bit wary of the django ORM after
> > reading...
>
> Yes, you are.
>
>
>
> > 'By default, a QuerySet will not eliminate duplicate rows. In
> > practice, this is rarely a problem, because simple queries such as
> > Blog.objects.all() don't introduce the possibility of duplicate result
> > rows. However, if your query spans multiple tables...'
>
> > Is someone out there really serious in assuming that using DISTINCT is
> > 'rarely a problem' due to most queries not needing to go beyond
> > 'Blog.objects.all()'?  Maybe I'm odd, but rarely do I have much use
> > for a single table query... not the other way around...
>
> Django behaves the same way as most experienced SQL writers. Using
> DISTINCT in a query can be avoided in a very large set of cases. It also
> introduces a lot of extra work into the query (since a sort is
> required). As SQL is about sets of rows, specifying things so that the
> duplicate rows aren't selected in the first place is preferred, rather
> than having to eliminate them from the result set.
>
> Single versus multi-table queries has no relevance to your question
> here. It's fairly common to have multi table queries created by Django
> and duplicate rows are only returned in very rare situations.
>
> What is the specific problem area you are working in that is routinely
> returning duplicate entries and where distinct() isn't solving the
> problem?
>
> > Not trying to be negative,
>
> And yet you're succeeding without any effort at all!
>
> Could you perhaps dial the attitude back a bit with all the "are you
> seriously..." stuff? Suffice it to say that Django is being used for at
> least a few thousand quite serious projects in more situations than you
> or I can imagine and by some organizations that even you would probably
> consider "serious".
>
> >  but I'm struggling with making the ORM
> > useful beyond quite simple (almost trivial) queries.
>
> Practice makes perfect.
>
> >   The ORM seems to
> > inevitably produce some seriously sloppy SQL under the covers.
>
> Concrete details are appreciated. I would dispute your claim, by the
> way, so what are the models you're using and the querysets you're
> constructing?
>
> At the end of the day, if Django isn't meeting your requirements, you
> should definitely look at some other options, however, none of the items
> you've posted really have enough details to allow us to suggest whether
> there are any obvious improvements. However, most of the things you've
> mentioned simply aren't issues in the majority situations I'm aware of
> (and I've seen and worked with both some very small sites and some huge
> ones), so generalisations aren't really appropriate. Asking questions
> about specific cases where you can provide a short self-contained code
> fragment to show what you're doing will be much more beneficial to all.
>
> Regards,
> Malcolm
--~--~---------~--~----~------------~-------~--~----~
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