summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/ansisql.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2007-04-11 20:55:27 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2007-04-11 20:55:27 +0000
commitaee39b2847e51518fa1382b245f2db674dab3e3e (patch)
tree437764619eeaa2754113302b5cd51769a639966c /lib/sqlalchemy/ansisql.py
parent95520005d5469f311f53ea9c51bbaef61be89178 (diff)
downloadsqlalchemy-aee39b2847e51518fa1382b245f2db674dab3e3e.tar.gz
- the "mini" column labels generated when using subqueries, which
are to work around glitchy SQLite behavior that doesnt understand "foo.id" as equivalent to "id", are now only generated in the case that those named columns are selected from (part of [ticket:513]) - MS-SQL better detects when a query is a subquery and knows not to generate ORDER BY phrases for those [ticket:513]
Diffstat (limited to 'lib/sqlalchemy/ansisql.py')
-rw-r--r--lib/sqlalchemy/ansisql.py19
1 files changed, 10 insertions, 9 deletions
diff --git a/lib/sqlalchemy/ansisql.py b/lib/sqlalchemy/ansisql.py
index 03053b998..c3170aa79 100644
--- a/lib/sqlalchemy/ansisql.py
+++ b/lib/sqlalchemy/ansisql.py
@@ -355,9 +355,7 @@ class ANSICompiler(sql.Compiled):
group_by = self.get_str(cs.group_by_clause)
if group_by:
text += " GROUP BY " + group_by
- order_by = self.get_str(cs.order_by_clause)
- if order_by:
- text += " ORDER BY " + order_by
+ text += self.order_by_clause(cs)
text += self.visit_select_postclauses(cs)
if cs.parens:
self.strings[cs] = "(" + text + ")"
@@ -460,7 +458,7 @@ class ANSICompiler(sql.Compiled):
inner_columns[self.get_str(co)] = co
# TODO: figure this out, a ColumnClause with a select as a parent
# is different from any other kind of parent
- elif select.is_subquery and isinstance(co, sql._ColumnClause) and not co.is_literal and co.table is not None and not isinstance(co.table, sql.Select):
+ elif select.is_selected_from and isinstance(co, sql._ColumnClause) and not co.is_literal and co.table is not None and not isinstance(co.table, sql.Select):
# SQLite doesnt like selecting from a subquery where the column
# names look like table.colname, so add a label synonomous with
# the column name
@@ -529,12 +527,8 @@ class ANSICompiler(sql.Compiled):
if t:
text += " \nHAVING " + t
- order_by = self.get_str(select.order_by_clause)
- if order_by:
- text += " ORDER BY " + order_by
-
+ text += self.order_by_clause(select)
text += self.visit_select_postclauses(select)
-
text += self.for_update_clause(select)
if getattr(select, 'parens', False):
@@ -556,6 +550,13 @@ class ANSICompiler(sql.Compiled):
return (select.limit or select.offset) and self.limit_clause(select) or ""
+ def order_by_clause(self, select):
+ order_by = self.get_str(select.order_by_clause)
+ if order_by:
+ return " ORDER BY " + order_by
+ else:
+ return ""
+
def for_update_clause(self, select):
if select.for_update:
return " FOR UPDATE"