.. changelog::
:version: 1.0.6
+ .. change::
+ :tags: bug, sql
+ :tickets: 3445
+
+ Fixed a bug where clause adaption as applied to a :class:`.Label`
+ object would fail to accommodate the labeled SQL expression
+ in all cases, such that any SQL operation that made use of
+ :meth:`.Label.self_group` would use the original unadapted
+ expression. One effect of this would be that an ORM :func:`.aliased`
+ construct would not fully accommodate attributes mapped by
+ :obj:`.column_property`, such that the un-aliased table could
+ leak out when the property were used in some kinds of SQL
+ comparisons.
+
.. change::
:tags: bug, documentation
:tickets: 2077
return self.element,
def _copy_internals(self, clone=_clone, anonymize_labels=False, **kw):
- self.element = clone(self.element, **kw)
+ self._element = clone(self._element, **kw)
+ self.__dict__.pop('element', None)
self.__dict__.pop('_allow_label_resolve', None)
if anonymize_labels:
self.name = self._resolve_label = _anonymous_label(
str(f1), str(f2)
)
+ def test_labeled_expression_adapt(self):
+ lbl_x = (t3.c.col1 == 1).label('x')
+ t3_alias = t3.alias()
+
+ adapter = sql_util.ColumnAdapter(t3_alias)
+
+ lblx_adapted = adapter.traverse(lbl_x)
+ is_not_(lblx_adapted._element, lbl_x._element)
+
+ lblx_adapted = adapter.traverse(lbl_x)
+ self.assert_compile(
+ select([lblx_adapted.self_group()]),
+ "SELECT (table3_1.col1 = :col1_1) AS x FROM table3 AS table3_1"
+ )
+
+ self.assert_compile(
+ select([lblx_adapted.is_(True)]),
+ "SELECT (table3_1.col1 = :col1_1) IS 1 AS anon_1 "
+ "FROM table3 AS table3_1"
+ )
+
def test_text(self):
clause = text(
"select * from table where foo=:bar",