summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/sql/expression.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2007-09-08 20:08:41 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2007-09-08 20:08:41 +0000
commit0ebccb4abd0eb39e6d8ecc9a9445cfcba0e10f9a (patch)
treed346390eb2689c7cdc60034a1161a4ff834ccc7a /lib/sqlalchemy/sql/expression.py
parentfc753a06475c2fa571d09d73d3169b66c272c8d6 (diff)
downloadsqlalchemy-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.py3
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)