summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2012-04-18 19:52:58 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2012-04-18 19:52:58 -0400
commit541e59c3d7c141cfe532b26b5fbf4b8a8d30b841 (patch)
treecb390b3341ddd4a0fdbd21646a7ee54f150b9b95 /lib/sqlalchemy
parentfdda4b0e018f8c1a869411b7ed31387ea90cb082 (diff)
downloadsqlalchemy-541e59c3d7c141cfe532b26b5fbf4b8a8d30b841.tar.gz
- [bug] UPDATE..FROM syntax with SQL Server
requires that the updated table be present in the FROM clause when an alias of that table is also present in the FROM clause. The updated table is now always present in the FROM, when FROM is present in the first place. Courtesy sayap. [ticket:2468]
Diffstat (limited to 'lib/sqlalchemy')
-rw-r--r--lib/sqlalchemy/dialects/mssql/base.py16
-rw-r--r--lib/sqlalchemy/sql/compiler.py2
2 files changed, 17 insertions, 1 deletions
diff --git a/lib/sqlalchemy/dialects/mssql/base.py b/lib/sqlalchemy/dialects/mssql/base.py
index 78da18711..3366d5fab 100644
--- a/lib/sqlalchemy/dialects/mssql/base.py
+++ b/lib/sqlalchemy/dialects/mssql/base.py
@@ -985,6 +985,22 @@ class MSSQLCompiler(compiler.SQLCompiler):
else:
return ""
+ def update_from_clause(self, update_stmt,
+ from_table, extra_froms,
+ from_hints,
+ **kw):
+ """Render the UPDATE..FROM clause specific to MSSQL.
+
+ In MSSQL, if the UPDATE statement involves an alias of the table to
+ be updated, then the table itself must be added to the FROM list as
+ well. Otherwise, it is optional. Here, we add it regardless.
+
+ """
+ return "FROM " + ', '.join(
+ t._compiler_dispatch(self, asfrom=True,
+ fromhints=from_hints, **kw)
+ for t in [from_table] + extra_froms)
+
class MSSQLStrictCompiler(MSSQLCompiler):
"""A subclass of MSSQLCompiler which disables the usage of bind
parameters where not allowed natively by MS-SQL.
diff --git a/lib/sqlalchemy/sql/compiler.py b/lib/sqlalchemy/sql/compiler.py
index fdff99fb1..bf234fe5c 100644
--- a/lib/sqlalchemy/sql/compiler.py
+++ b/lib/sqlalchemy/sql/compiler.py
@@ -1115,7 +1115,7 @@ class SQLCompiler(engine.Compiled):
"""Provide a hook to override the generation of an
UPDATE..FROM clause.
- MySQL overrides this.
+ MySQL and MSSQL override this.
"""
return "FROM " + ', '.join(