# initialize all the column, etc. objects. done after
# reflection to allow user-overrides
self._init_items(*args)
-
- key = property(lambda self:_get_table_key(self.name, self.schema))
+
+ def key(self):
+ return _get_table_key(self.name, self.schema)
+ key = property(key)
def _export_columns(self, columns=None):
# override FromClause's collection initialization logic; Table implements it differently
self.constraints.remove(self._primary_key)
self._primary_key = pk
self.constraints.add(pk)
- primary_key = property(lambda s:s._primary_key, _set_primary_key)
+
+ def primary_key(self):
+ return self._primary_key
+ primary_key = property(primary_key, _set_primary_key)
def __repr__(self):
return "Table(%s)" % ', '.join(
self._info = kwargs.pop('info')
if kwargs:
raise exceptions.ArgumentError("Unknown arguments passed to Column: " + repr(kwargs.keys()))
-
- columns = property(lambda self:[self])
-
+
def __str__(self):
if self.table is not None:
if self.table.named_with_column:
"""
return self._params(True, optionaldict, kwargs)
+
def params(self, *optionaldict, **kwargs):
"""Return a copy with ``bindparam()`` elments replaced.
elif len(optionaldict) > 1:
raise exceptions.ArgumentError("params() takes zero or one positional dictionary argument")
- class Vis(visitors.ClauseVisitor):
- def visit_bindparam(self, bind):
- if bind.key in kwargs:
- bind.value = kwargs[bind.key]
- if unique:
- bind._convert_to_unique()
- return Vis().traverse(self, clone=True)
+ def visit_bindparam(bind):
+ if bind.key in kwargs:
+ bind.value = kwargs[bind.key]
+ if unique:
+ bind._convert_to_unique()
+ return visitors.traverse(self, visit_bindparam=visit_bindparam, clone=True)
def compare(self, other):
"""Compare this ClauseElement to the given ClauseElement.
def __truediv__(self, other):
return self.operate(operators.truediv, other)
-# precedence ordering for common operators. if an operator is not
-# present in this list, it will be parenthesized when grouped against
-# other operators
-_smallest = object()
-_largest = object()
-
-PRECEDENCE = {
- operators.from_:15,
- operators.mul:7,
- operators.div:7,
- operators.mod:7,
- operators.add:6,
- operators.sub:6,
- operators.concat_op:6,
- operators.ilike_op:5,
- operators.notilike_op:5,
- operators.like_op:5,
- operators.notlike_op:5,
- operators.in_op:5,
- operators.notin_op:5,
- operators.is_:5,
- operators.isnot:5,
- operators.eq:5,
- operators.ne:5,
- operators.gt:5,
- operators.lt:5,
- operators.ge:5,
- operators.le:5,
- operators.between_op:5,
- operators.distinct_op:5,
- operators.inv:5,
- operators.and_:3,
- operators.or_:2,
- operators.comma_op:-1,
- operators.as_:-1,
- operators.exists:0,
- _smallest: -1000,
- _largest: 1000
-}
-
class _CompareMixin(ColumnOperators):
"""Defines comparison and math operations for ``ClauseElement`` instances."""
def replace_selectable(self, old, alias):
"""replace all occurences of FromClause 'old' with the given Alias object, returning a copy of this ``FromClause``."""
- from sqlalchemy.sql import util
- return util.ClauseAdapter(alias).traverse(self, clone=True)
+ from sqlalchemy.sql.util import ClauseAdapter
+ return ClauseAdapter(alias).traverse(self, clone=True)
def corresponding_column(self, column, require_embedded=False):
"""Given a ``ColumnElement``, return the exported ``ColumnElement``
return None
type = property(type)
- columns = []
-
def _copy_internals(self, clone=_clone):
self.bindparams = dict([(b.key, clone(b)) for b in self.bindparams.values()])
return f
def self_group(self, against=None):
- if self.group and self.operator != against and PRECEDENCE.get(self.operator, PRECEDENCE[_smallest]) <= PRECEDENCE.get(against, PRECEDENCE[_largest]):
+ if self.group and self.operator != against and operators.is_precedent(self.operator, against):
return _Grouping(self)
else:
return self
self.clause_expr = clauses.self_group()
else:
self.clause_expr = clauses
-
- key = property(lambda self:self.name or "_calc_")
+
+ def key(self):
+ return self.name or '_calc_'
+ key = property(key)
def _copy_internals(self, clone=_clone):
self.clause_expr = clone(self.clause_expr)
args = [_literal_as_binds(c, self.name) for c in clauses]
self.clause_expr = ClauseList(operator=operators.comma_op, group_contents=True, *args).self_group()
self.type = sqltypes.to_instance(kwargs.get('type_', None))
-
- key = property(lambda self:self.name)
- columns = property(lambda self:[self])
+
+ def key(self):
+ return self.name
+ key = property(key)
+
+ def columns(self):
+ return [self]
+ columns = property(columns)
def _copy_internals(self, clone=_clone):
_CalculatedClause._copy_internals(self, clone=clone)
return super(_UnaryExpression, self)._negate()
def self_group(self, against):
- if self.operator and PRECEDENCE.get(self.operator, PRECEDENCE[_smallest]) <= PRECEDENCE.get(against, PRECEDENCE[_largest]):
+ if self.operator and operators.is_precedent(self.operator, against):
return _Grouping(self)
else:
return self
self.left.compare(other.left) and
self.right.compare(other.right) or
(
- self.operator in [operators.eq, operators.ne,
- operators.add, operators.mul] and
+ operators.is_commutative(self.operator) and
self.left.compare(other.right) and
self.right.compare(other.left)
)
def self_group(self, against=None):
# use small/large defaults for comparison so that unknown
# operators are always parenthesized
- if self.operator != against and (PRECEDENCE.get(self.operator, PRECEDENCE[_smallest]) <= PRECEDENCE.get(against, PRECEDENCE[_largest])):
+ if self.operator != against and operators.is_precedent(self.operator, against):
return _Grouping(self)
else:
return self