summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/dialects/mssql
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/dialects/mssql
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/dialects/mssql')
-rw-r--r--lib/sqlalchemy/dialects/mssql/base.py16
1 files changed, 16 insertions, 0 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.