]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/commitdiff
Fixed bug where using an annotation such as :func:`.remote` or
authorMike Bayer <mike_mp@zzzcomputing.com>
Tue, 8 Oct 2013 23:47:13 +0000 (19:47 -0400)
committerMike Bayer <mike_mp@zzzcomputing.com>
Tue, 8 Oct 2013 23:49:09 +0000 (19:49 -0400)
:func:`.foreign` on a :class:`.Column` before association with a parent
:class:`.Table` could produce issues related to the parent table not
rendering within joins, due to the inherent copy operation performed
by an annotation. [ticket:2813]

Conflicts:
lib/sqlalchemy/sql/elements.py

doc/build/changelog/changelog_08.rst
lib/sqlalchemy/sql/util.py
test/sql/test_selectable.py

index 54e10ec64aeabc4fdc1120c3e62f638777b4aaf8..70521ecbf6c6023fddf4df07209e993cb924b157 100644 (file)
 .. changelog::
     :version: 0.8.3
 
+    .. change::
+        :tags: bug, orm
+        :tickets: 2813
+        :versions: 0.9.0
+
+        Fixed bug where using an annotation such as :func:`.remote` or
+        :func:`.foreign` on a :class:`.Column` before association with a parent
+        :class:`.Table` could produce issues related to the parent table not
+        rendering within joins, due to the inherent copy operation performed
+        by an annotation.
+
     .. change::
         :tags: bug, sql
         :tickets: 2831
index 61730f1f02b9621fec49ee4997a33c45dab5f5da..fdc5bb3725149e7fe1a27accf2828e8b3e63eb3d 100644 (file)
@@ -497,7 +497,7 @@ class Annotated(object):
 class AnnotatedColumnElement(Annotated):
     def __init__(self, element, values):
         Annotated.__init__(self, element, values)
-        for attr in ('name', 'key'):
+        for attr in ('name', 'key', 'table'):
             if self.__dict__.get(attr, False) is None:
                 self.__dict__.pop(attr)
 
@@ -506,6 +506,11 @@ class AnnotatedColumnElement(Annotated):
         """pull 'name' from parent, if not present"""
         return self._Annotated__element.name
 
+    @util.memoized_property
+    def table(self):
+        """pull 'table' from parent, if not present"""
+        return self._Annotated__element.table
+
     @util.memoized_property
     def key(self):
         """pull 'key' from parent, if not present"""
index 03357eb740898b5c85e19391b1af1fdcf2c743b3..649490ef30ab32b8775b9a4def3cc6532a271115 100644 (file)
@@ -10,6 +10,7 @@ from sqlalchemy.sql import util as sql_util, visitors, expression
 from sqlalchemy import exc
 from sqlalchemy.sql import table, column, null
 from sqlalchemy import util
+from sqlalchemy.schema import Column, Table, MetaData
 
 metadata = MetaData()
 table1 = Table('table1', metadata,
@@ -1380,6 +1381,12 @@ class AnnotationsTest(fixtures.TestBase):
         c1.name = 'somename'
         eq_(c1_a.name, 'somename')
 
+    def test_late_table_add(self):
+        c1 = Column("foo", Integer)
+        c1_a = c1._annotate({"foo": "bar"})
+        t = Table('t', MetaData(), c1)
+        is_(c1_a.table, t)
+
     def test_custom_constructions(self):
         from sqlalchemy.schema import Column
         class MyColumn(Column):