diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-09-08 20:08:41 +0000 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-09-08 20:08:41 +0000 |
| commit | 0ebccb4abd0eb39e6d8ecc9a9445cfcba0e10f9a (patch) | |
| tree | d346390eb2689c7cdc60034a1161a4ff834ccc7a /lib/sqlalchemy/sql/expression.py | |
| parent | fc753a06475c2fa571d09d73d3169b66c272c8d6 (diff) | |
| download | sqlalchemy-0ebccb4abd0eb39e6d8ecc9a9445cfcba0e10f9a.tar.gz | |
[ticket:768] dont assume join criterion consists only of column objects
Diffstat (limited to 'lib/sqlalchemy/sql/expression.py')
| -rw-r--r-- | lib/sqlalchemy/sql/expression.py | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/sqlalchemy/sql/expression.py b/lib/sqlalchemy/sql/expression.py index f3c17236d..b1a5bf96f 100644 --- a/lib/sqlalchemy/sql/expression.py +++ b/lib/sqlalchemy/sql/expression.py @@ -2188,6 +2188,7 @@ class Join(FromClause): encodedname = property(lambda s: s.name.encode('ascii', 'backslashreplace')) def _init_primary_key(self): + from sqlalchemy import schema pkcol = util.Set([c for c in self._flatten_exportable_columns() if c.primary_key]) equivs = {} @@ -2200,7 +2201,7 @@ class Join(FromClause): class BinaryVisitor(visitors.ClauseVisitor): def visit_binary(self, binary): - if binary.operator == operators.eq: + if binary.operator == operators.eq and isinstance(binary.left, schema.Column) and isinstance(binary.right, schema.Column): add_equiv(binary.left, binary.right) BinaryVisitor().traverse(self.onclause) |
