summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/sql/compiler.py
diff options
context:
space:
mode:
authormike bayer <mike_mp@zzzcomputing.com>2021-05-05 16:36:08 +0000
committerGerrit Code Review <gerrit@ci3.zzzcomputing.com>2021-05-05 16:36:08 +0000
commit03d922d4ee35d6a02ffe4f06dc2fd2670c4f3f50 (patch)
tree784c56748b4e3a9f8ec7b3ddc9181a7c5d36cef1 /lib/sqlalchemy/sql/compiler.py
parentb5927dd9229d9ce85fc2ba25dad10ecbb749195c (diff)
parent5af854606b6aabb7eb07311572acafe01cc73737 (diff)
downloadsqlalchemy-03d922d4ee35d6a02ffe4f06dc2fd2670c4f3f50.tar.gz
Merge "Parenthesize for empty not in"
Diffstat (limited to 'lib/sqlalchemy/sql/compiler.py')
-rw-r--r--lib/sqlalchemy/sql/compiler.py16
1 files changed, 9 insertions, 7 deletions
diff --git a/lib/sqlalchemy/sql/compiler.py b/lib/sqlalchemy/sql/compiler.py
index 57ffdf86b..437a11a60 100644
--- a/lib/sqlalchemy/sql/compiler.py
+++ b/lib/sqlalchemy/sql/compiler.py
@@ -1908,7 +1908,9 @@ class SQLCompiler(Compiled):
return self._render_in_expr_w_bindparam(binary, operator, **kw)
def visit_not_in_op_binary(self, binary, operator, **kw):
- return self._render_in_expr_w_bindparam(binary, operator, **kw)
+ return "(%s)" % self._render_in_expr_w_bindparam(
+ binary, operator, **kw
+ )
def _render_in_expr_w_bindparam(self, binary, operator, **kw):
opstring = OPERATORS[operator]
@@ -1957,10 +1959,13 @@ class SQLCompiler(Compiled):
if parameter.type._is_tuple_type:
replacement_expression = (
"VALUES " if self.dialect.tuple_in_values else ""
- ) + self.visit_empty_set_expr(parameter.type.types)
+ ) + self.visit_empty_set_op_expr(
+ parameter.type.types, parameter.expand_op
+ )
+
else:
- replacement_expression = self.visit_empty_set_expr(
- [parameter.type]
+ replacement_expression = self.visit_empty_set_op_expr(
+ [parameter.type], parameter.expand_op
)
elif isinstance(values[0], (tuple, list)):
@@ -3939,9 +3944,6 @@ class StrSQLCompiler(SQLCompiler):
for t in extra_froms
)
- def visit_empty_set_op_expr(self, type_, expand_op):
- return self.visit_empty_set_expr(type_)
-
def visit_empty_set_expr(self, type_):
return "SELECT 1 WHERE 1!=1"